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Foreword 2004: 
the Annals edition 


The publication of this new edition of Algorithmic Graph Theory and 
Perfect Graphs marks twenty three years since its first appearance. My original 
motivation for writing the book was to collect and unify the topic to act as a 
spring board for researchers, and especially graduate students, to pursue new 
directions of investigation. The ensuing years have been an amazingly fruitful 
period of research in this area. To my great satisfaction, the number of relevant 
journal articles in the literature has grown tenfold. I can hardly express my 
admiration to all these authors for creating a success story for algorithmic graph 
theory far beyond my own imagination. 

The world of perfect graphs has grown to include over 200 special graph 
classes. The Venn diagrams that I used to show some of the inclusions between 
classes in the First Generation, for example Figure 9.9 (on page 212), have 
yielded to Hasse diagrams for the Second Generation, like the one from 
Golumbic and Trenk [2004] reprinted in Figure 13.3 at the end of this edition. 

Perhaps the most important new development in the theory of perfect graphs 
is the recent proof of the Strong Perfect Graph Conjecture by Chudnovsky, 
Robertson, Seymour and Thomas, announced in May 2002. News of this was im- 
mediately passed on to Claude Berge, who sadly passed away on June 30, 2002. 

On the algorithmic side, many of the problems which were open in 1980 
have subsequently been settled, and algorithms on new classes of perfect graphs 
have been studied. For example, tolerance graphs generalize both interval graphs 
and permutation graphs, and coloring tolerance graphs in polynomial time is 
important in solving scheduling problems where a measure of flexibility or 
tolerance is allowed for sharing or relinquishing resources when total exclusivity 
prevents a solution. 

At the end of this new edition, I have added a short chapter called 
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Epilogue 2004 in which I survey a few of my favorite results and research 
directions from the Second Generation. Its intension is to whet the appetite. 
Six books have appeared recently which cover advanced research in this area. 
They have thankfully relieved me from a pressing need to write my own encyclo- 
pedia sequel. They are the following, and are a must for any graph theory library. 
* A. Brandstadt, V.B. Le and J.P. Spinrad, “Graph Classes: A Survey”, SIAM, 
Philadelphia [1999], is an extensive and invaluable compendium of the current 
status of complexity and mathematical results on hundreds on families of 
graphs. It is comprehensive with respect to definitions and theorems, citing 
over 1100 references. 
PC. Fishburn, “/nterval Orders and Interval Graphs: A Study of Partially 
Ordered Sets”, John Wiley & Sons, New York [1985], gives a comprehensive 
look at the research on this class of ordered sets. 
M.C. Golumbic and A.N. Trenk, “Tolerance Graphs”, Cambridge University 
Press [2004], is the youngest addition to the perfect graph bookshelf. It 
contains the first thorough study of tolerance graphs and tolerance orders, and 
includes proofs of the major results which have not appeared before in books. 
N.V.R. Mahadev and U.N. Peled, “Threshold Graphs and Related Topics”, 
North-Holland [1995], is a thorough and extensive treatment of all research 
done in the past years on threshold graphs (chapter 10 of my book), threshold 
dimension and orders, and a dozen new concepts which have emerged. 
T.A. McKee and ER. McMorris, “Jopics in Intersection Graph Theory”, 
SIAM, Philadelphia [1999], is a focused monograph on structural properties, 
presenting definitions, major theorems with proofs and many applications. 
W.T. Trotter, “Combinatorics and Partially Ordered Sets”, Johns Hopkins, 
Baltimore [1992], is the book to which I referred at the bottom of page 136. 
It covers new directions of investigation and goes far beyond just dimension 
problems on ordered sets. 


Algorithmic Graph Theory and Perfect Graphs has now become the classic 
introduction to the field. It continues to convey the message that intersection 
graph models are a necessary and important tool for solving real-world problems. 
Solutions to the algorithmic problems on these special graph classes are 
continually integrated into systems for a large variety of application areas, 
from VLSI circuit design to scheduling, from resource allocation to physical 
mapping of DNA, from temporal reasoning in artificial intelligence to pavement 
deterioration analysis. On the mathematical side, perfect graph classes have 
provided rich soil for deep theoretical results. In short, it remains a stepping stone 
from which the reader may embark on one of many fascinating research trails. 


Martin Charles Golumbic 
Haifa, Israel 


Foreword 


Research in graph theory and its applications has increased considerably in 
recent years, Typically, the elaboration of new theoretical structures has moti- 
vated a search for new algorithms compatible with those structures. Rather than 
the arduous and systematic study of every new concept definable with a graph, 
the main task for the mathematician is to eliminate the often arbitrary and cum- 
bersome definitions, keeping only the “‘deep’’ mathematical problems. 

Of course, the deep problems may well be elusive; indeed, there have been 
many definitions (from Dieudonné, among others) of what a deep problem is. In 
graph theory, it should relate to a variety of other combinatorial structures and 
must therefore be connected with many difficult practical problems. Among 
these will be problems that classical algebra is not able to solve completely or 
that the computer scientist would not attack by himself. 

This book, by Martin Golumbic, is intended as an introduction to graph theory 
through just these practical problems, nearly all of them related to the structure of 
permutation graphs, interval graphs, circle graphs, threshold graphs, perfect 
graphs, and others. 

The reader will not find motivations drawn from number theory, as is usual for 
most of the extremal graph problems, or from such refinements of old riddles as 
the four-color problem and the Hamiltonian tour. Instead, Golumbic has selected 
practical problems that occur in operations research, scheduling, econometrics, 
and even genetics or ecology. 

The author’s point of view has also enjoyed increasing favor in the area of 
complexity analysis. Each time a new structure appears, the author immediately 
devotes some effort to a description of efficient algorithms, if any are known to 
exist, and to a determination of whether a proposed algorithm is able to solve the 
problem within a reasonable amount of time. 
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Certainly a wealth of literature on graph theory has developed by now. Yet it is 
clear that this book brings a new point of view and deserves a special place in the 
literature. 


CLAUDE BERGE 


Preface 


The notion of a ‘‘perfect”’ graph was introduced by Claude Berge at the birth 
of the 1960s. Since that time many classes of graphs, interesting in their own 
right, have been shown to be perfect. Research, in the meantime, has proceeded 
along two lines. The first line of investigation has included the proof of the 
perfect graph theorem (Theorem 3.3), attempts at proving the strong perfect 
graph conjecture, studies of critically imperfect graphs, and other aspects of 
perfect graphs. The second line of approach has been to discover mathematical 
and algorithmic properties of special classes of perfect graphs: comparability 
graphs, triangulated graphs, and interval graphs, to name just a few. Many of 
these graphs arise quite naturally in real-world applications. For example, uses 
include optimization of computer storage, analysis of genetic structure, synchro- 
nization of parallel processes, and certain scheduling problems. 

Recently it appeared to me that the time was ripe to assemble and organize the 
many results on perfect graphs that are scattered throughout the literature, some 
of which are difficult to locate. A serious attempt has been made to coordinate 
the mélange of some 200 papers referenced here in a manner that would make the 
subject more accessible to those interested in algorithmic and algebraic graph 
theory. I have tried to include most of the important results that are currently 
known. In addition, a few new results and new proofs of old results appear 
throughout the text. In particular, Chapter 9, on superperfect graphs, contains 
results due to Alan J. Hoffman, Ellis Johnson, Larry I. Stockmeyer, and myself 
that are appearing in print for the first time. 

The emphasis of any book naturally reflects the bias of the author. As a mathe- 
matician and computer scientist, I am doubly biased. First, I have tried to present 
a rigorous and coherent theory. Proofs are constructive and are streamlined as 
much as possible. The notation has been chosen to facilitate these matters. Sec- 
ond, I have directed much attention to the algorithmic aspects of every problem. 
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xviii Preface 


Algorithms are expressed in a manner that will make their adaptation to a partic- 
ular programming language relatively easy. The complexity of every algorithm is 
analyzed so that some measure of its efficiency can be determined. 

These two approaches enhance one another very well. By exploiting the math- 
ematical properties satisfied a priori by a structure, one is often able to reduce the 
time or space complexity required to solve a problem. Conversely, the al- 
gorithmic approach often leads to startling theoretical results. To illustrate this 
point, consider the fact that certain NP-complete problems become tractable 
when restricted to certain classes of perfect graphs, whereas the algorithm for 
recognizing comparability graphs gives rise to a matroid associated with the 
graph. 

A glance at the table of contents will provide a rough outline of the topics to be 
discussed. The first two chapters are introductory in the sense that they provide 
the foundations, respectively, of the graph theoretic notions and the algorithmic 
design and analysis techniques that will be used in the remaining chapters. The 
reader may wish to read these two chapters quickly and refer to them as needed. 
The chapters are structured in such a way that the book will be suitable as a 
textbook in a course on algorithmic combinatorics, graph theory, or perfect 
graphs. In addition, the book will be very useful for applied mathematicians and 
computer scientists at the research level. Many applications of the theoretical and 
computational aspects of the subject are described throughout the text. At the end 
of each chapter there are numerous exercises to test the reader’s understanding 
and to introduce further results. An extensive bibliography follows each chapter, 
and, when possible, the Mathematical Reviews number is included for further 
reference. 

The topics covered in this book have been chosen to fill a vacuum in the 
literature, and their interrelation and importance will become evident as early as 
Section 1.3. Since the intersection of this volume with the traditional material 
covered by most graph theory books has been designed to be small, it is highly 
recommended that the serious student augment his studies with one of these 
excellent textbooks. A one-year course with two concurrent texts is suggested. 


MARTIN CHARLES GOLUMBIC 
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Corrections and Errata to: 
Algorithmic Graph Theory 
and Perfect. Graphs, 

the original 1980 edition 


We apologize to Prof. George Lueker for misspelling his family name 
throughout the text. Hence all occurrences “Leuker” should be “Lueker’. 


Page 18: The graph in Figure 1.17 is a circular-arc graph. 
Page 48: Exercise 21 is false. 
Page 49: Garey and Johnson [1978]: add “MR80g:68056” 


Page 78: Bland, et al. [1979]: add “MR80g:05034” 
Chvatal, et al. [1979]: add “MR81b:05044” 
de Werra [1978]: add “MR81a:05052” 
Greenwell [1978]: add “MR80d:05044” 


Page 79: Olaru [1977]: add “MR58#5411” 


Page 80: Parthasarathy and Ravindra [1979]: add “MR80m:05045” 
Pretzel [1979]: add “MR80d:06003” 
Tucker [1979]: add “MR81c:05041” 
Wagon [1978]: add “MR80i:05078” 


Page 85: Figure 4.3: The edge (5, e) is missing. 
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Page 104: 


Page 138: 


Page 145: 
Page 146: 
Page 147: 


Page 156: 


Page 163: 


Page 179: 


Page 190: 


Corrections and Errata 


Exercise 24: The claim in the first sentence is false. For example, 
it can use as many as 7 colors on the graph Gj), in Figure 4.1. 
A different technique can be used to obtain a linear time coloring 
algorithm for triangulated graphs, which is due to Martin Farber. 
Line 21: change “As/j(w)” to “Adj(u)” 

Gavril [1978]: add “MR81g:05094” 


Wagon [1978]: add “MR80i:05078” 


The second footnote can be updated since M. Yannakakis has now 
proved that the complexity of determining if a poset has dimension 
3 is NP-complete. 


Pretzel [1979]: add “MR80d:06003” 
Gysin [1977]: add “MR58#5393” 
Rabinovitch [1978b]: add “MR58#5424” 


Burkard and Hammer [1977]: change to the following: 
[1980] A note on Hamiltonian split graphs, J Combin. Theory B 28, 
245-248. MR81e:05095. 


A necessary condition for the existence of a Hamiltonian cycle in 
split graphs is proved. 

Erdos and Gallai [1960]: change “272” to “274” 

Foldes and Hammer [1978]: add “MR80c:05111” 


Hammer, Ibaraki, and Simeone [1978]: change to the following: 
[1978] Degree sequences of threshold graphs, Proc. 9th Southeastern 
Conf. on Combinatorics, Graph Theory and Computing, Con- 
gressus Numeratium 21, Utilitas Math., Winnipeg, Man., 329-355. 
MR80j:05088. 


There should be edges between 3-4 and 6-7 (corrected in this 
edition). 


Figure 8.7: The second tree on the right should have its rightmost 
leaf “F” rather than “E”. The leaves should read from left to nght as 
follows: BCEADF 


line 6: change “will appear in Tucker [1979]” to: “appears in Tucker 
[1980]” 
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Page 197: 


Page 198: 


Page 199: 


Page 201: 


Page 202: 


Page 203: 


Page 206: 


Page 212: 


Page 234: 


line 26: change “Griggs and West [1979]” to: “Griggs and West 
{1980]” 
Abbott and Katchalski [1979]: add “MR80b:05038” 


Booth and Lueker [1976]: add “MR55#6932” 


Griggs [1979]: add “MR81h:05083b” 

Griggs and West: change to the following: 

[1980] Extremal values of the interval number of a graph, SIAM J 
Algebraic Discrete Methods 1, 1-7. MR81h:05083a. 


Roberts [1979a]: add “MR81e:05120” 
Roberts [1979b]: add “MR81e:05071” 
Trotter and Harary [1979]: add “MR81c:05055” 


Tucker [1979]: change to the following: 
[1980] An efficient test for circular-arc graphs, SIAM J. Comput. 9, 
1-24. MR81a:68074. 


line 17: add the following: 
Vertices x of weight w(x) = 0 are the mapped into the empty interval. 


@(T;w) should be w(G; w) 


Figure 9.9: 

(1) The nonsuperperfect, interval graph with the chordless 5-cycle 
should have two chords connecting the top two vertices to the 
bottom vertex. It will then be the same as the “bull’s head” graph 
on page 16, (corrected in this edition). 

(2) The noncomparability, nontriangulated comparability graph on 
7 vertices has too many edges. The two vertical edges should 
be removed, (corrected in this edition). 

(3) The nonsuperperfect, interval graph which has 5 triangles, is, in 
fact, superperfect; it should be moved into the superperfect, non- 
compatability, interval area of the figure. See also Section 13.9 
of the Epilogue to this edition. 


Golumbic [1978a]: add “MR81e:68080” 

Hammer, Ibaraki, and Simeone [1978]: change to the following: 
[1978] Degree sequences of threshold graphs, Proc. 9th Southeastern 
Conf. on Combinatorics, Graph Theory and Computing, Con- 
gressus Numeratium 21, Utilitas Math., Winnipeg, Man., 329-355. 
MR80j:05088. 


xxvi Corrections and Errata 


Page 253: Gavril [1973]: change “minimum independent” to “maximum inde- 
pendent” 


Page 267: Golumbic [1979]: add “MR81c:05077” 
Golumbic and Goss [1978]: add “MR80d:05037” 
Ohtsuki, Cheung, and Fujisawa [1976]: add “MR58#5379” 


Page 280: Lueker, G. S.: change “25” to “24” 
Put name into alphabetical order. 


CHAPTER | 


Graph Theoretic Foundations 


1. Basic Definitions and Notations 


Functions and Relations 


Let X and Y be sets. A function (or mapping) f from X to Y, denoted 
fx Y, 
is a rule which associates to each element x of X a corresponding element 
y of Y. It is usual to call y the image of x under f and denote it by y = f(x). 


We call fan injective or one-to-one function if no pair of distinct members of 
X has the same image under f, that is, 


X#X >f(X) FSO) (x, x’ X), 
or equivalently, 
fO=f%)=x=x' (x, x’eX). 


The function fis called surjective or onto if each y in Y is the image of some x 
in X, that is, 


(Vy e Y)(Ax € X) such that y = f(x). 


A function which is both injective and surjective is called a bijection. A 
permutation is simply a bijection from a set to itself. 

Following the usual notation of mathematics, x €¢ X indicates that x is a 
member of the set X and A ¢ X means that A is a (not necessarily proper) 
subset of X. The cardinality or size of X 1s denoted by | X |. For subsets A and 
B of X, the notation A ~ Band A uv Bare the usual set intersection and set 


1 


2 1. Graph Theoretic Foundations 


union operations. When A and B are disjoint subsets, we often write their 
union with a plus sign. That is, 


C=A+B indicates ANB=Q@ and C=AvUB, 


where @ is the empty set. Throughout this book we will deal exclusively with 
finite sets. A collection {X;},-, of subsets of a set X is said to cover X if their 
union equals X. The collection is called a partition of X if the subsets are 
pairwise disjoint and the collection covers X. 

Let A(X) denote the power set of a set X, i.e., the collection of all subsets of 
X. It is well known that | A(X)| = 2'*!. A binary relation on X is defined to be 
a function 

R: X > AX) 


from X to the power set of X. For each x € X, the image of x under R is a 
subset R(x) S X called the set of relatives of x. It is customary to represent 
the relation R as a collection of ordered pairs 2 S X x X, where 


(y xJEP if and only if x’ e€ R(x). 


In this case we say that x’ is related to x. Notice that this does not necessarily 
imply that x is related to x’. (Perhaps one should read “will inherit from” 
instead of “is related to,” as in the case of a poor nephew with ten children 
and his rich widowed childless aunt.) 

A binary relation R on X may satisfy one or more of the following prop- 
erties: 


symmetric property 
x’ € R(x) > xe R(x’) (x, x’e X), 
antisymmetric property 
x’ E R(x) > x¢ R(x’) (x, x’ € X), 
reflexive property 
x € R(x) (xe€ X), 
irreflexive property 
x€R(x) (xe X), 
transitive property 
z€ R(y), ye R(x) > ze R(x) (x, y, Z€ X). 


Such a relation is said to be an equivalence if it is reflexive, symmetric, and 
transitive. A binary relation is called a strict partial order if it is irreflexive and 
transitive. It is a simple exercise to show that a strict partial order will also be 
antisymmetric. 
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Let us formally define the notion of a graph. A graph* G consists of a finite 
set V and an irreflexive binary relation on V. We call V the set of vertices. The 
binary relation may be represented either as a collection E of ordered pairs or 
as a function from V to its power set, 


Adj: V — AV). 


Both of these representations will be used interchangeably. We call Adj(v) 
the adjacency set of vertex v, and we call the ordered pair (v, w) € E an edge. 
Clearly 


(v, WEE ifand only if we Adj(v). 


In this case we say that w is adjacent to v and v and w are endpoints of the edge 
(v, w). The assumption of irreflexivity implies that 


(x, )¢E (ve), 
or equivalently, 

v ¢ Adj(v) (ve V). 
We further denote 

N(v) = {v} + Adj(r), 


which is called the neighborhood of v. 
In this book we will usually drop the parentheses and the comma when 
denoting an edge. Thus 


xyeE and (x, y)EE 


will have the same meaning. This convention, we believe, improves the clarity 
of exposition. 

We have defined a graph as a set and a certain relation on that set. It is often 
convenient to draw a “picture” of the graph. This may be done in many ways. 
Usually one draws a circle for each vertex and:connects vertex x and vertex y 
with a directed arrow whenever xy is an edge. If both xy and yx are edges, then 
sometimes a single line joins x and y without arrows. Figure 1.1 shows three 
of the many possible drawings that one could use to represent the same graph. 
In each case the adjacency structure remains unchanged. Occasionally, very 
intelligent persons will become extremely angry because one does not like the 
other’s pictures. When this happens it is best to remember that our figures 
are meant simply as a tool to help understand the underlying mathematical 
structure or as an aid in constructing a mathematical model for some appli- 
cation. 


* Some authors use the term directed graph or digraph. 
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d a 


Figure 1.1. Three pictures of the same graph. 


Two graphs G = (V, E) and G’ = (V’, E’) are called isomorphic, denoted 
G = G,, if there is a bijection f: V > V’ satisfying, for all x, ye V, 


(x, YE E <> (f(x), f(y) € E’. 


Two edges are adjacent if they share a common endpoint; otherwise they are 
nonadjacent. 


Let G = (V, E) be a graph with vertex set V and edge set E. The graph 

G~! = (V, E~') is said to be the reversal of G, where 
E~* = {(x, y)i(y, x) € E}, 
that is, 
xyeE"'<syxeE (x, yeV). 
We define symmetric closure of G to be the graph G = (V, E), where 
E=EvE"?. 
A a G = (V, E) is called undirected if its adjacency relation is symmetric, 
Le., i 
E=E"}, 
or equivalently, 
E=E. 


We occasionally denote an undirected edge by ab = {ab} U {ba}. A graph 
H =(V, F) is called an oriented graph if its adjacency relation is antisym- 
metric, Le., if 


FOF U=@. 


If, in addition, F + F~! = E, then H (or F) is called an orientation of G 
(or E). The four nonisomorphic orientations of the pentagon are given in 
Figure 1.2. 

Let G = (V, E) be an undirected graph. We define the complement of G 
to be the graph G = (V, E), where 


E = {(x, y)eV x V|x # yand (x, y)¢ E}. 
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Pentagon 


onenene 


Figure 1.2. The four nonisomorphic orientations of the pentagon. 


Intuitively, the edges of G become the nonedges of G and vice versa. A graph 
is complete if every pair of distinct vertices is adjacent. Thus, the complement 
G = (V, E) of G could equivalently be defined as that set E satisfying E 0 E 
= @ and E + E complete. The complete graph on n vertices is usually 
denoted by K,, (see Figure 1.3). 

A (partial) subgraph of a graph G = (V, E) is defined to be any graph H = 
(M’, E’) satisfying V’ ¢ V and E’ € E. Two types of subgraphs are of particu- 
lar importance, namely, the subgraph spanned by a given subset of edges and 
the subgraph induced by a given subset of vertices. They will now be described. 

A subset S ¢ E of the edges spans the subgraph H = (Vy, S), where 
Vs = {ve V |v is an endpoint of some edge of S}. We call H the (partial) 
subgraph spanned by S. 


Okay partner, 
hand over that 


triangle |! 


-3 


Figure 1.3. Some complete graphs. 
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Figure 1.4. Examples of subgraphs. 


Given a subset A & V of the vertices, we define the subgraph induced by A 
to be G4 = (A, E,), where 


E, = {xy€ E|xeA and ye A}. 


For ve A we denote Adj,4(v) = Adj(v) 0 A. Obviously not every subgraph 
of G is an induced subgraph of G (Figure 1.4). 


Let G = (V, E) be an undirected graph. Consider the following definitions. 


Clique: A subset A © V ofr vertices is an r-clique if it induces a complete 
subgraph, i.e., if G4 = K,. A single vertex is a 1-clique. A clique A is maximal 
if there is no clique of G which properly contains A as a subset. A clique is 
maximum if there is no clique of G of larger cardinality. Some authors use the 
term complete set to indicate a clique. 


@(G) is the number of vertices in a maximum clique of G; it is called the 
clique number of G. 


A clique cover of size k is a partition of the vertices V = A, + A, +--- 
+ Aj, such that each A, is a clique. 


k(G) is the size of a smallest possible clique cover of G; it is called the 
clique cover number of G. 


A stable set is a subset X of vertices no two of which are adjacent. Some 
authors use the term independent set to indicate a stable set. 


a(G) is the number of vertices in a stable set of maximum cardinality; it is 
called the stability number of G. 
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A proper c-coloring is a partition of the vertices V = X, + X,+---+ X, 
such that each X; is a stable set. In such a case, the members of X; are 
“painted” with the color i and adjacent vertices will receive different colors. 
We say that G is c-colorable. It is common to omit the word proper; a coloring 
will always be assumed to be a proper coloring. 


x(G) is the smallest possible c for which there exists a proper c-coloring of 
G; it is called the chromatic number of G. 


It is easy to see that 
o(G) < x(G) and a(G) < k(G), 


since every vertex of a maximum clique (maximum stable set) must be con- 
tained in a different partition segment in any minimum proper coloring 
(minimum clique cover). There is an obvious duality to these notions, 
namely, 


w(G)=«(G) and ¥(G)= k(G). 


Let G = (V, E) be an arbitrary graph. The out-degree of a vertex x, de- 
noted by d*(x), is defined as d*(x) = |Adj(x)|. The in-degree d~ (x) of x 
is defined similarly: 


d(x) = |{ye V|x € Adj(y)}]. 
Although in general d*(x) and d~ (x) will not be equal, we do have 
dX d*(x) = 2d) =|E|, 


xeVv 
each ordered pair in E contributing 1 to both summands, A vertex whose out- 
degree (in-degree) equals zero is called a sink (source). If both d*(x) = 0 and 
d™ (x) = 0, then x is an isolated vertex. 

When G is an undirected graph the situation is somewhat special. In such a 
case d*(x) = d™(x) for each x € V, and we call this number simply the degree 
of x, denoted d(x). That is, the degree of x in an undirected graph is the size of 
its adjacency set. Finally, defining || E|| = 4|E| we obtain the familiar formula 


$d ax) = |El. 
xeV 
Let G = (V, E) be an arbitrary graph. We present some fairly standard 


definitions. 


Chain: A sequence of vertices [v 9, v1, ¥2,..., 0,] is a chain of length lin G 
if v;_,0,¢ E or U;0;-1 € E for i= 1, 2, vey L 


Path: A sequence of vertices [v9, v1, v2,..., | is a path from vp to v, of 
length lin G provided that v,;_,v,¢ E fori = 1,2,..., 1 
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ININUN 


Figure 1.5. 


A path or chain in G is called simple if no vertex occurs more than once. It 
is called trivial if 1 = 0. 


Connected graph: A graph G is connected if between any two vertices there 
exists a chain in G joining them. 


Strongly connected graph: A graph G is strongly connected if for any two 
vertices x and y there exists a path in G from x to y. 


Remark. The notions of chain and path coincide when G is an undirected 
graph. 


Cycle: A sequence of vertices [v9, 01, 02, ..-, Uj, Vo] is called a cycle of 
length | + 1 (or closed path) if v;_ ,v,;¢ E for i = 1, 2,..., land vj,vg € E. 


Simple cycle: A cycle [vo, 04, V2, ..., Vj, Uo] is a simple cycle if v; 4 v, for 
i # j. 

Chordless cycle: A simple'cycle [v9, 01, ¥2,..., ¥1; Vo] is chordless if v;v; ¢ E 
for i and j differing by more than 1 mod / + 1. 


Bipartite graph: An undirected graph G = (V, E) is bipartite if its vertices 
can be partitioned into two disjoint stable sets V = S, + S,, ie., every edge 
has one endpoint in S, and the other in $,. Equivalently, G is bipartite if and 
only if it is 2-colorable. It is customary to use the notation G = (S,, S>, E), 
which emphasizes the partition. Vertices x ¢S; and yeS, are of the same 
parity if i = j and are of opposite parity if i # j. 
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Complete bipartite graph: A bipartite graph G = (S,, S,, E) is complete if 
for every x ES, and ye S, we have xy€ E, i.e., every possible edge that could 
exist does exist. 


Throughout the text certain graphs will occur many times. We give names 
to some of them (see Figure 1.5). 


K,: the complete graph on n vertices or n-clique. 

C,: the chordless cycle on n vertices or n-cycle. 

P,: the chordless path graph on n vertices or n-path. 

Ky: the complete bipartite graph on m + n vertices partitioned into an 
m-stable set and an n-stable set. 

K, ,: the star graph on n + 1 vertices. 

mK,,: m disjoint copies of K,,. 


There is obviously some overlap with these names. For example, K; = C; is 
called a triangle. Notice also that C, = 2K, and K,,, = 2K,. 


2. Intersection Graphs 


Let ¥ bea family of nonempty sets. The intersection graph of F is obtained 
by representing each set in ¥ by a vertex and connecting two vertices by an 
edge if and only if their corresponding sets intersect. When F¥ is allowed to be 
an arbitrary family of sets, the class of graphs obtained as intersection graphs 
is simply all undirected graphs (Marczewski [1945}). The problem of char- 
acterizing the intersection graphs of families of sets having some specific 
topological or other pattern is often very interesting and frequently has 
applications to the real world. 

The intersection graph of a family of intervals on a linearly ordered set 
(like the real line) is called an interval graph. If these intervals are required 
to have unit length, then we have a unit interval graph; a proper interval graph 
is constructed from a family of intervals on a line such that no interval prop- 
erly contains another. Roberts [1969a] showed that the classes of unit in- 
terval graphs and proper interval graphs coincide. Interval graphs are 
discussed in Section 1.3 and in Chapter 8. 

Consider the following relaxation of the notion of intervals on a line. If we 
join the two ends of our line, thus forming a circle, the intervals will become 
arcs on the circle. Allowing arcs to slip over and include the point of connec- 
tion, we obtain a class of intersection graphs called the circular-arc graphs, 
which properly contains the interval graphs. Circular-arc graphs have been 
extensively studied by A. C. Tucker and others. We will survey these results 
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in Section 8.6. There are a number of interesting applications of circular-arc 
graphs, including computer storage allocation and the phasing of traffic 
lights. Let us look at an example of the latter application. 


Example. The traffic flow at the corner of Holly, Vood, and Wine is 
pictured in Figure 1.6. Certain lanes are compatible with one another, such 
as c and j, or d and k, while others are incompatible, such as b and f. In order 
to avoid collisions, we wish to install a traffic light system to control the flow 
of vehicles. Each lane will be assigned an arc on a circle representing the time 
interval during which it has a green light. Incompatible lanes must be assigned 
disjoint arcs. The circle may be regarded as a clock representing an entire 
cycle which will be continually repeated. An arc assignment for our example 
is given in Figure 1.7. In general, if G is the intersection graph of the arcs of 
such an assignment (see Figure 1.8), and if H is the compatibility relation 
defined on the pairs of lanes, then clearly G is a (partial) subgraph of H. In 
our example, the compatible pairs (d, k), (h, j), and (i,j) are in H but are not in 
G. Additional aspects of this problem, such as how to choose an arc assign- 
ment which minimizes waiting time, can also be incorporated into the model. 
The reader is referred to Stoffers [1968] and Roberts [1976, pp. 129-134; 
1978, Section 3.6] for more details. 


A proper circular-arc graph is the intersection graph of a family of arcs 
none of which properly contains another. It can be shown (Theorem 8.18) 


Holly Street 


Wine Avenue 


Figure 1.6. 
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Figure 1.7. The clock cycle. 


that every proper circular-arc graph has a representation as intersecting 
arcs of a circle in which not only is no arc properly contained in another but 
also no pair of arcs together cover the entire circle. 

In a different generalization of interval graphs, Renz [1970] characterized 
the intersection graphs of paths in a tree, and Gavril [1978] gives a recogni- 
tion algorithm for them. Walter [1972], Buneman [1974], and Gavril [1974] 
carried this idea further and showed that the intersection graphs of subtrees of 
a tree are exactly the triangulated graphs of Chapter 4. All of this is summar- 
ized in Figure 1.9. 

A permutation diagram consists of n points on each of two parallel lines 
and n straight line segments matching the points. The intersection graph of 
the line segments is called a permutation graph. These graphs will be discussed 


Figure 1.8. G, the circular-arc graph. 
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Figure 1.9. 


in Chapter 7. If the 2n points are located randomly around a circle, then the 
matching segments will be chords of the circle and the resulting class of 
intersection graphs, studied in Chapter 11, properly contains the permutation 
graphs. A simple argument shows that every proper circular-arc graph is also 
the graph of intersecting chords of a circle: We may assume that no pair of 
arcs together covers the entire circle (Theorem 8.18). For each arc on the 
circle, draw the chord connecting its two endpoints. Clearly, two arcs overlap 
if and only if their corresponding chords intersect. 

There are many other interesting classes of intersection graphs. We have 
introduced you to only some of them, specifically those classes which will 
be developed further in the text. To the reader who wishes to investigate other 
intersection graphs we offer the following references: 


Cubes and boxes in n-space: Danzer and Grunbaum [1967], 
Roberts [1969b]. 

Convex sets in n-space: Wegner [1967], 
Ogden and Roberts [1970]. 
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3. Interval Graphs—A Sneak Preview of the Notions 
Coming Up 


Our intention in this section is to arouse the reader’s curiosity by presenting 
some basic ideas that will be pursued in greater detail in later chapters. We 
also hope to imbue the reader with a sense of how the subject matter is 
relevant to applied mathematics and computer science. 

An undirected graph G is called an interval graph if its vertices can be put 
into one-to-one correspondence with a set of intervals ¥ of a linearly ordered 
set (like the real line) such that two vertices are connected by an edge of G if 
and only if their corresponding intervals have nonempty intersection. We 
call ¥ an interval representation for G. (It is unimportant whether we use open 
intervals or closed intervals; the resulting class of graphs will be the same.) An 
interval representation of the windmill graph is given in Figure 1.10. 

Let us discuss one application of interval graphs. Many other such 
applications will be presented in Section 8.4. 


Application to Scheduling 


Consider a collection C = {c;} of courses being offered by a major uni- 
versity. Let T; be the time interval during which course c¢; is to take place. We 
would like to assign courses to classrooms so that no two courses meet in the 
same room at the same time. 

This problem can be solved by properly coloring the vertices of the graph 
G =(C, E) where 


cjcje E> T,0T; # S. 


Each color corresponds to a different classroom. The graph G is obviously an 
interval graph, since it is represented by time intervals. 


a b i 
; ; 4 l, ‘, i 
fi —_— — — — 
. @ 1, fy of 4, 
f e 


Figure 1.10. An interval graph—the windmill graph (at left)—and an interval representation 
for it. 
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This example is especially interesting because efficient, linear-time 
algorithms are known for coloring interval graphs with a minimum number 
of colors. (The minimum coloring problem is NP-complete for general 
graphs, Section 2.1.) We will discuss these algorithms in subsequent chapters. 


Remark. The determination of whether a given graph is an interval 
graph can also be carried out in linear time (Section 8.3). 


We have chosen interval graphs as an introduction to our studies because 
they satisfy so many interesting properties. The first fact that we notice is 
that being an interval graph is a hereditary property. 


Proposition 1.1. An induced subgraph of an interval graph is an interval 
graph. 


Proof. If {I,},-y is an interval representation for a graph G = (V, E), 
then {/,},-x is an interval representation for the induced subgraph G, = 
(X, Ey). 


Hereditary properties abound in graph theory. Some of our favorites 
include planarity, bipartiteness, and any “forbidden subgraph” char- 
acterization. The next property of interval graphs is also a hereditary 
property. 


Triangulated graph property. Every simple cycle of length strictly greater 
than 3 possesses a chord. 


Graphs which satisfy this property are called triangulated graphs. The 
graph in Figure 1.10 is triangulated, but the house graph in Figure 1.11 is not 


triangulated because it contains a chordless 4-cycle. 


Proposition 1.2 (Hajés [1958]). An interval graph satisfies the triangu- 
lated graph property. 


Figure 1.11. A graph which is not triangulated: The house graph. 
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Figure 1.12. A triangulated graph which is not an interval graph. 


Proof. Suppose the interval graph G contains a chordless cycle [v9, v,, 
V2,.-+5V,—1309] with] > 3. Let I, denote the interval corresponding to v,. For 
i= 1,2,...,1 — 1, choose a point p,€1;_, OJ;. Since I;_, and I,,, do not 
overlap, the p; constitute a strictly increasing or strictly decreasing sequence. 
Therefore, it is impossible for Jy and J,_, to intersect, contradicting the 
criterion that vo v,_ , is an edge of G. | 


Not every triangulated graph is an interval graph. Consider the tree T 
given in Figure 1.12, which certainly has no chordless cycles. The intervals 
I,,1,, and I, of a representation for T would have to be disjoint, and I, would 
properly include the middle interval, say I,,. Where, then, could we put I, so 
that it intersects I, but not I,? Clearly we would be stuck. So there must be 
more to the story of interval graphs than we have told so far. 


Transitive orientation property. Each edge can be assigned a one-way 
direction in such a way that the resulting oriented graph (V, F) satisfies the 
following condition: 


abe FandbceF imply aceF (Va, b, cE V). (1) 


An undirected graph which is transitively orientable is sometimes called a 
comparability graph. Figure 1.13 shows a transitive orientation of the A 
graph and of the suspension bridge graph. The odd length chordless cycles 
Cs, C;, Co,... and the bull’s head graph (see Figure 1.14) cannot be transi- 
tively oriented. 


Proposition 1.3 (Ghouila-Houri [1962]). The complement of an interval 
graph satisfies the transitive orientation property. 


Proof. Let {I,},-y be an interval representation for G = (V, E). Define 
an orientation F of the complement G = (V, E) as follows: 


xyeFel, <I,  (VxyeE). 
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The A graph The suspension bridge graph 
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Figure 1.13. Transitive orientations of two comparability graphs. 


Here I,, < J, means that the interval I, lies entirely to the left of the interval 
I,. (Remember, they are disjoint.) Clearly (1) is satisfied, since I, < I, < I, 
implies J, < I,. Thus, F is a transitive orientation of G. | 


As in the case of triangulated graphs, there are graphs whose complements 
are comparability graphs but which fail to be interval graphs. So it seems that 
Propositions 1.2 and 1.3 simply provide necessary (but not sufficient) condi- 
tions for interval graphs. Rather than wait any longer, we state an important 
result that says, if we put these two properties together, we get (drum roll, 
please) exactly all interval graphs. 


Theorem 1.4 (Gilmore and Hoffman [1964]). An undirected graph G 
is an interval graph if and only if Gis a triangulated graph and its complement 
G is a comparability graph. 


The proof of sufficiency is postponed until Chapter 8, primarily because 
this is a “getting acquainted with” section. 

Looking back, each of the graphs in Figures 1.10, 1.11, and 1.13 can be 
properly colored using three colors and each contains a triangle. Therefore, 


Cs The bull's head graph 


Figure 1.14. Two graphs which are not transitively orientable. Why? 
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for these graphs, their chromatic number equals their clique number. This is 
not an accident. In Chapters 4 and 5 we will show that any triangulated graph 
and any comparability graph also satisfies the following properties. 


y-Perfect property. For each induced subgraph G, of G, 


UGa) = o(Ga). 


The chordless cycles C,, C,, Cg are not y-perfect. A dual notion of y-perfec- 
tion is the following: 


a-Perfect property. For each induced subgraph G, of G, 
a(G4) = k(Gy). 


A very important theorem in Chapter 3 states that a graph is y-perfect if and 
only if it is «-perfect. This equivalence was originally conjectured by Claude 
Berge, and it was proved some ten years later by Laszl6 Lovasz. 


4. Summary 


The reader has been introduced to the graph theoretic foundations needed 
for the remainder of the book. In addition, he has had a taste of some of the 
particular notions that we intend to investigate further. Returning to the 
table of contents at this point, he will recognize many of the topics listed. 
The chapter dependencies are given in Figure 1.15. 


Figure 1.15. The chapter dependencies. The reader may wish to read Chapters 1 and 2 
quickly and refer back to them as needed. 
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In the next chapter we will present the foundations of algorithmic design 
and analysis. As was the case in this chapter, many examples will be given 
which will introduce the reader to the ideas and techniques that he will find 
helpful in subsequent chapters. 


EXERCISES 


1. Show that the graphs in Figures 1.16 and 1.17 are both intersection graphs 
of a family of chords of a circle but that neither is a circular-arc graph. 


Figure 1.16. Figure 1.17. 


2. Can you find graphs for each zone of the Venn diagram in Figure 1.9? 
3. Let ¥ be a family of intervals on a line such that no interval contains 
another. Show that none of the left endpoints coincide. Give a procedure 
which constructs a family ¥’ of unit intervals such that the intersection graphs 
of ¥ and ¥' are isomorphic. 

4. Let G = (V, E) be any undirected graph. Show that there is a family F¥ of 
subsets of V such that G is the intersection graph of ¥. 

5. Let G be the intersection graph of a family of paths in a tree and let v bea 
vertex of G. Show that the induced subgraph G,,) + aajq) is an interval graph. 
6. Prove directly (using only the definition) that the graph in Figure 1.17 
does not have an interval representation and is therefore not an interval 
graph. 

7. Give an interval representation for the graph in Figure 1.18. Show that 
it is not a comparability graph. Why is this not in conflict with the Gilmore— 


Hoffman theorem? 


Figure 1.18. 


8. Give a graph theoretic solution to the following problem: A group of 
calculus teaching assistants each gives two office hours weekly which are 
chosen in advance. Because of budgetary reasons, the TAs must share 
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offices. Since each office has only one blackboard, how can office space be 
assigned so that at any particular time no more than one TA is meeting with 
students? 

9. Give an example to show that the graph you obtain in Exercise 8 is not 
necessarily an interval graph. How could we alter the problem so that we 
would obtain only interval graphs? 

10. Is the bull’s head graph (Figure 1.14) an interval graph? Is the comple- 
ment of the suspension bridge graph (Figure 1.13) an interval graph? What is 
a good name for this last graph? 

11. An undirected graph is self-complementary if it is isomorphic to its 
complement. Show that there are exactly two self-complementary graphs 
having five vertices. How many are there for four vertices? Six vertices? 

12. Let G = (V, E) be an undirected graph. A subset A © V is called an 
edge cover of G if for every edge xy€ E, either x € A or ye A or both. Prove 
that A is a minimum edge cover if and only if V — Ais a maximum stable set. 
13. Let F = {S,},-y be a family of subsets of a set. Two members S,, and 
S, of F overlap, denoted S, 4 S,, if S, 1S, # OW, S, F S,, and S, ¢ S,. The 
overlap graph of F is the undirected graph G = (V, E) where 


xye€E ifandonlyif S, 4S, (x, ye V). 


(i) Show that if x and y are in separate connected components Gy 
and G, of G, then 


S, S S,>S, & S, (aé A). 


(ii) Let Y be the collection of (maximal) connected components of G. 
Show that the relation <, defined for all G4, Gg eG as 


G4 < Gg dx eA, ye B such that Sy © Sy, 


is a Strict partial order of Y. 

14. A family ¥ of distinct nonempty subsets ofa set S is a representation of a 
graph G if the intersection graph of ¥ is isomorphic to G. A representation is 
minimum if the set S is of smallest possible cardinality over all representations 
of G. A graph G is uniquely intersectable if for all minimum representations 
¥F, and ¥, of G, F, and F, are isomorphic. 

(i) Prove that every triangle-free graph is uniquely intersectable. 

A star n-gon is constructed from the cycle C,, by adjoining new vertices to 
the endpoints of each edge. Figure 1.19 illustrates a star 7-gon. 

ii) Verify that the family F = {So,S,,...,5,-1,Do, D,,.-.,D,-,}isa 
minimum representation of the star n-gon, where S; = {i} and D, = 
{i,i + 1 mod 7}. 

Gii) Prove that every star n-gon is uniquely intersectable (Alter and 
Wang [1977]). 
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Figure 1.19. A star 7-gon. 


15. The Berge mystery story. Six professors had been to the library on the day 
that the rare tractate was stolen. Each had entered once, stayed for some time, 
and then left. If two were in the library at the same time, then at least one of 
them saw the other. Detectives questioned the professors and gathered the 
following testimony: Abe said that he saw Burt and Eddie in the library; Burt 
said that he saw Abe and Ida; Charlotte claimed to see Desmond and Ida; 
Desmond said that he saw Abe and Ida; Eddie testified to seeing Burt and 
Charlotte; Ida said that she saw Charlotte and Eddie. 
One of the professors lied!! Who was it? 


Research Problem. Characterize uniquely intersectable graphs and/or give 
a recognition algorithm. 


Bibliography 


Alter, R., and Wang, C. C. 
[1977] Uniquely intersectable graphs, Discrete Math. 18, 217-226. 
Berge, Claude 
[1973] ‘‘Graphs and Hypergraphs,” Chapter 16, North-Holland. Amsterdam, 1973. 
MRS50 #9640. 
[1975] Perfect graphs, in “ Studies in Graph Theory,” Part I(D. R. Fulkerson, ed.), pp. 1-22. 
M.A.A. Studies in Mathematics Vol. 11, Math. Assoc. Amer., Washington, D.C. 
MRS3 #10585, 
Buneman, Peter 
[1974] A characterization of rigid circuit graphs, Discrete Math. 9, 205-212. MR50 # 9686. 
Danzer, L., and Grunbaum, B. 
[1967] Intersection properties of boxes in R*, unpublished mimeograph, Univ. of Washing- 
ton, Seattle. 


Bibliography 21 


Erddés, P., Goodman, A., and Pésa, L., 
[1966] The representation of a graph by set intersections, Canad. J. Math. 18, 106-112. 
MR32 #4034. 
Gavril, Fanica 
[1974] The intersection graphs of subtrees in trees are exactly the chordal graphs, J. Combin- 
atorial Theory B 16, 47-56. MR48 #10868. 
[1978] A recognition algorithm for the intersection graphs of paths in trees, Discrete Math. 
23, 211-227. 
Ghouila-Houri, Alain 
({1962] Caractérisation des graphes non orientés dont on peut orienter les arrétes de maniére 
a obtenir le graphe d’une relation d’ordre, C. R. Acad. Sci. Paris 254, 1370-1371, 
MR30 #2495. 
Gilmore, Paul C., and Hoffman, Alan J. 
[1964] A characterization of comparability graphs and of interval graphs, Canad. J. Math. 
16, 539-548. MR31 #87. 
Hajés, G. 
[1957] Uber eine Art von Graphen, Intern. Math. Nachr. 11, Problem 65. 
First posed the problem of characterizing interval graphs. 
Marczewski, E. 
[1945] Sur deux propriétés des classes d’ensembles, Fund. Math. 33, 303-307. 
Ogden, W. F., and Roberts, Fred S. 
[1970] Intersection graphs of families of convex sets with distinguished points, in ‘‘Com- 
binatorial Structures and Their Applications” (R. Guy, H. Hanani, N. Sauer, and 
J. Schénheim, eds.), pp. 311-313. Gordon and Breach, New York. 
Renz, P. L. 
[1970] Intersection representations of graphs by arcs, Pacific J. Math. 34, 501-510. MR42 
#5839, 
Roberts, Fred S. 
[1969a] Indifference graphs, in “Proof Techniques in Graph Theory” (F. Harary, ed.), pp. 
139-146, Academic Press, New York. MR40 #5488. 
[1969b] On the boxity and cubicity of a graph, in ‘“‘Recent Progress in Combinatorics” 
(W. T. Tutte, ed.), pp. 301-310. Academic Press, New York. 
[1976] ‘‘Discrete Mathematical Models, with Applications to Social, Biological, and 
Environmental Problems.” Prentice-Hall, Englewood Cliffs, New Jersey. 
[1978] Graph Theory and its Applications to Problems of Society, NFS-CBMS Mono- 
graph No. 29. SIAM, Philadelphia, Pennsylvania. 
Stoffers, K. E. 
[1968] Scheduling of traffic lights—a new approach, Transportation Res. 2, 199-234, 
Walter, J. R. 
[1972] Representations of rigid cycle graphs, Ph.D. thesis, Wayne State Univ. 
Wang, D. L. 
[1976] A note on uniquely intersectable graphs, Studies in Appl. Math. 55, 361-363. 
Wegner, G. 
[1967] Eigenschaften der Nervan Homologische-einfacher Familien in R", Ph.D. thesis, 
GOttingen. 


CHAPTER Z 


The Design of 
Efficient Algorithms 


1. The Complexity of Computer Algorithms 


With the advent of the high-speed electronic computer, new branches of 
applied mathematics have sprouted forth. One area that has enjoyed a most 
rapid growth in the past decade is the complexity analysis of computer 
algorithms. At one level, we may wish to compare the relative efficiencies of 
procedures which solve the same problem. At a second level, we can ask 
whether one problem is intrinsically harder to solve than another problem. 
It may even turn out that a task is too hard for a computer to solve within a 
reasonable amount of time. Measuring the costs to be incurred by imple- 
menting various algorithms is a vital necessity in computer science, but it 
can be a formidable challenge. 

Let us reflect for a moment on the differences between computability and 
computational complexity. These two topics, along with formal languages, 
become the pillars of the theory of computation. Computability addresses 
itself mostly to questions of existence: Is there an algorithm which solves 
problem IT? An early surprise for many math and computer science students 
is that one can prove mathematically that computers cannot do everything. 
A standard example is the unsolvability of the halting problem. Loosely 
stated, this says that it is impossible for a professor to write a computer program 
which will accept as data any student’s programming assignment and will 
return either the answer “ yes, this student’s program will halt within finite time” 
or “no, this student’s program (has an infinite loop and) will run forever.” 
Proving that a problem is computable usually, but not always, consists of 
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demonstrating an actual algorithm which will terminate with a correct 
answer for every input. The amount of resources (time and space) used in the 
calculation, although finite, is unlimited. Thus, computability gives us an 
understanding of the capabilities and limitations of the machines that man- 
kind can build, but without regard to resource restrictions. 

In contrast to this, computational complexity deals precisely with the 
quantitative aspects of problem solving. It addresses the issue of what can be 
computed within a practical or reasonable amount of time and space by 
measuring the resource requirements exactly or by obtaining upper and 
lower bounds. Complexity is actually determined on three levels: the problem, 
the algorithm, and the implementation. Naturally, we want the best algorithm 
which solves our problem, and we want to choose the best implementation of 
that algorithm. 

A problem consists of a question to be answered, a requirement to be 
fulfilled, or a best possible situation or structure to be found, called a solution, 
usually in response to several input parameters or variables, which are 
described but whose values are left unspecified. A decision problem is one 
which requires a simple “yes” or “no” answer. An instance of a problem IT is 
a specification of particular values for its parameters. An algorithm for I is a 
step-by-step procedure which when applied to any instance of IT produces 
a solution. 

Usually we can rewrite an optimization problem as a decision problem 
which at first seems to be much easier to solve than the original but turns out 
to be just about as hard. Consider the following two versions of the graph 
coloring problem. 


GRAPH COLORING (optimization version) 

Instance: An undirected graph G. 

Question: What is the smallest number of colors needed for a proper coloring 
of G? 


GRAPH COLORING (decision version) 
Instance: An undirected graph G and an integer k > 0. 
Question: Does there exist a proper k coloring of G? 


The optimization version can be solved by applying an algorithm for the 
decision version n times for an n-vertex graph. If the n decision problems are 
solved sequentially, then the time needed to solve the optimization version is 
larger than that for the decision version by at most a factor of n. However, if 
they can be solved simultaneously (in parallel), then the time needed for 
both versions is essentially the same. 

It is customary to express complexity as a function of the size of the input. 
We say that an algorithm .o¢ for IT runs in time O( f(m)) if for some constant 
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c > 0 there exists an implementation of . which terminates after at most 
cf (m) (computational) steps for all instances of size m. The complexity of an 
algorithm .f is the smallest function f such that o runs in O(f(m)). The 
complexity of a problem II is the smallest {for which there exists an O( f(m))- 
time algorithm . for TH, ie., the minimum complexity over all possible 
algorithms solving IT. Thus, demonstrating and analyzing the complexity of a 
particular algorithm for 1 provides us with an upper bound on the complexity 
of I1.* 

By presenting faster and more efficient algorithms and implementations of 
algorithms, successive researchers have improved the complexity upper 
bounds (i.e., lowered them) for many problems in recent years. Consider the 
example of testing a graph for planarity. A graph is planar if it can be drawn on 
the plane (or on the surface of a sphere) such that no two edges cross one 
another. Kuratowski’s [1930] characterization of planar graphs in terms of 
forbidden configurations provides an obvious exponential-time planarity 
algorithm, namely, verify that no subset of vertices induces a subgraph 
homeomorphic to K, or 2K3. Auslander and Parter [1961] gave a planar 
embedding procedure, which Goldstein [1963] was able to formulate in such 
a way that halting was guaranteed. Shirey [1969] implemented this algorithm 
to run in O(n*) time for an n-vertex graph. In the meantime, Lempel, Even, 
and Cederbaum [1967] gave a different planarity algorithm, and, although 
they did not specify a time bound, an easy O(n”) implementation exists. 
Hopcroft and Tarjan [1972, 1974] then improved the Auslander-Parter 
method first to O(n log n) and finally to O(n), which is the best possible. 
Booth and Leuker showed that the Lempel-Even—Cederbaum method 
could also be implemented to run in O(n) time. Table 2.1 shows the stages of 
improvement for the planarity problem and for the maximum-network-flow 
problem. Tarjan [1978] summarizes the progress on a number of other 
problems. 

Determining the complexity of a problem II requires a two-sided attack: 


(1) The upper bound—the minimum complexity over all known algorithms 
solving II. 

(2) The lower bound—the largest function f for which it has been proved 
(mathematically) that all possible algorithms solving II are required to have 
complexity at least as high as f. 


Our ultimate goal is to make these bounds coincide. A gap between (1) and 
(2) tells us how much more research is needed to achieve this goal. For many 


* We have just described the worst-case complexity analysis. One may also formulate 
complexity according to the average case. A good discussion of the pros and cons of average-case 
analysis can be found in Weide [1977, Section 4]. 
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Table 2.1 


Progress on the complexity of two combinatorial problems 


Planarity: Maximum network fiow: 
A graph with n vertices A network with n vertices and e edges 
exp Kuratowski [1930] Nonterminating Ford and 
under certain Fulkerson [1962] 
conditions 
{ ne? Edmonds and Karp 
ne Auslander and Parter [1972]° 
[1961] 
Goldstein [1963] 
Shirey [1969] 
ne Dinic [1970] 
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nr Lempel, Even, and ne Karzanov [1974] 
Cederbaum [1967] | 
nlogn Hopcroft and Tarjan nreh!2 Cherkasky [1977] 
[1972] 
n Hopcroft and Tarjan ndi3e2/3 Galil [1978] 
[1974] 
Booth and Leuker 
[1976] nelog?n — Galil and Naamad 


? [1979] 


“Done independently. 


problems this gap is stubbornly large. An example of this is the problem of 
matrix multiplication. 

In Strassen [1969] an algorithm is presented for multiplying a pair of 
2 x 2 matrices using only seven scalar multiplications. It is now known that 
seven multiplications is the best possible. For arbitrary n x n matrices 
Strassen’s algorithm may be applied recursively (by first embedding the 
matrices into the next larger power of 2 in size) to obtain a general algorithm 
whose complexity is O(n'°*?”) ~ O(n?-81). Until recently, O(n?-**) was the 
best result known. The best algorithm known for the case of 3 x 3 matrices is 
given by Laderman [1976]; it uses 23 scalar multiplications. By appropriately 
composing these two methods with themselves or each other, we can obtain 
the best algorithms known for n = 4, 6, 7, 8, 9, and many other values. For 
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n= 5, G. A. Schachtel has an algorithm using 103 multiplications, an im- 
provement of one given by O. Sykora, which used 105. Asymptotically, 
however, in order to improve Strassen’s general bound, one would need an 
algorithm for n = 3 using 21 or fewer multiplications (since log, 21 < 
log, 7 < log; 22) or an algorithm for n = 5 using 91 or fewer multiplications, 
etc. Amazingly, Pan [1978, 1979a] has discovered a collection of algorithms 
which do improve upon Strassen’s bound. The best of these is an algorithm 
for n = 48 which uses 47,216 multiplications. Since logy, 47,216 ~ 2.78, 
Pan’s algorithm has a complexity of O(n?-78). In very recent work Pan 
[1979b] has reduced the complexity down to O(n?:°°°*) for very large n. 
This is currently the upper bound for the matrix multiplication problem. 
On the other hand, the tightest lower bound known to date for this problem 
is only O(n’) [see Aho, Hopcroft, and Ullman, 1974, p. 438]. 

The biggest open question involving the gap between upper and lower 
complexity bounds involves the so called NP-complete problems (discussed 
below). For each of the problems in this class only exponential-time algo- 
rithms are known, yet the best lower bounds proven so far are polynomial 
functions. Furthermore, if a polynomial-time algorithm exists for one of 
them, then such an algorithm exists for all of them. Included among the 
NP-complete problems on graphs are finding a Hamiltonian circuit, a 
minimum coloring, or a maximum clique. Appendix A contains a small 
collection of NP-complete problems which will suffice for the purposes of 
this book. For a more comprehensive list, the reader is referred to Garey and 
Johnson [1978]. Let us discuss the basics of this theory. 

The state of an algorithm consists of the current values of all variables 
and the location of the current instruction to be executed. A deterministic 
algorithm is one for which each state upon execution of the instruction unique- 
ly determines at most one next state. Virtually all computers, as we know 
them, run deterministically. A problem IT is in the class P if there exists a 
deterministic polynomial-time algorithm which solves IT. 

A nondeterministic algorithm is one for which a state may determine many 
next states and which follows up on each of the next states simultaneously. 
We may regard a nondeterministic algorithm as having the capability of 
branching off into many copies of itself, one for each next state. Thus, while a 
deterministic algorithm must explore a set of alternatives one at a time, a 
nondeterministic algorithm examines all alternatives at the same time. 

Following Reingold, Nievergelt, and Deo [1977], three special instruc- 
tions are used in writing nondeterministic algorithms for decision problems: 


x © choice(S) creates | S| copies of the algorithm, and assigns every member 
of the set S to the variable x in one of the copies. 


failure causes that copy of the algorithm to stop execution. 
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success causes all copies of the algorithm to stop execution and indicates 
a “yes” answer to that instance of the problem. 


A nondeterministic polynomial-time algorithm for the decision version of 
the CLIQUE problem is the following: Let G = (V, E) be an undirected 
graph and let k > 0. 


procedure CLIQUE(G, k): 
begin 
Ae D 
for all ve Vdo A < choice({A + {v}, A});; 
if | A| < & then failure; 
for allv, we A,v 4 wdo 
if vv ¢ E then failure;; 
. success ; 
end 


DAuARwnNo 


The loop in line 2 nondeterministically selects a subset of vertices A © V; 
lines 4-6 decide if A is a complete set. If success is reached in one of the 
copies, then the final value of A in that copy is a clique of size at least k. Using 
the above procedure we obtain a nondeterministic polynomial-time algo- 
rithm for the optimization version of the CLIQUE problem as follows: Let 
G be an undirected graph with n vertices. 


procedure MAXCLIQUE(G): 
begin 
fork — nto 1 step —1 do 
if CLIQUE(G, k) then return £; 
end 


A problem IT is in the class NP if there exists a nondeterministic polynomial- 
time algorithm which solves I]. We have just demonstrated that CLIQUE 
é NP by presenting an appropriate algorithm. Clearly, P ¢ NP. An im- 
portant open question in the theory of computation is whether the contain- 
ment of P in NP is proper; i.e., is P # NP? 

One problem I], is polynomially transformable to another problem I1,, 
denoted II, < lq, if there exists a function f mapping the instances of I], 
into the instances of IT, such that 


(i) fis computable deterministically in polynomial time, and 
(ii) a solution to the instance f(J) of I, gives a solution to the instance I 
of IT,, for all J. 


Intuitively this means that IT, is no harder to solve than II, up to an added 
polynomial term, for we could solve II, by combining the transformation f 
with the best algorithm for solving IT,. Thus, if II, < TI,, then 


COMPLEXITY(II,) < COMPLEXITY(I,) + POLYNOMIAL. 
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If Ii, has a deterministic polynomial-time algorithm, then so does I1,; if 
every deterministic algorithm solving II, requires at least an exponential 
amount of time, then the same is true of I,. 

A problem IT is NP-hard if any one of the following equivalent conditions 
holds: 


(A,) <0 for all TI’e NP; 

(H,) MeP=+>P= NP; 

(H,) the existence of a deterministic polynomial-time algorithm for T 
would imply the existence of a polynomial-time algorithm for every problem 
in NP. 


A problem I is NP-complete if it is both a member of NP and is NP-hard 
(see Figure 2.1). The NP-complete problems are the most difficult of those in 
the “zone of uncertainty.” 

The topic of NP-completeness was initiated by Cook [1971]. Emphasizing 
the significance of polynomial-time reducibility, he focused attention on NP 
decision problems. He proved that the SATISFIABILITY problem of 
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Figure 2.1. The hierarchy of complexities. The big open question is whether or not the 
“zone of uncertainty,” NP-P, is empty. 
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mathematical logic is NP-complete (Cook’s theorem), and he suggested 
other problems which might be NP-complete. Karp [1972] presented a 
large collection of NP-complete problems (about two dozen) arising from 
combinatorics, logic, set theory, and other areas of discrete mathematics. 
In the next few years, hundreds of problems were shown to be NP-complete. 
The standard technique employed with NP-completeness is as follows: First, 
by Cook’s theorem, place SATISFIABILITY in the bag of NP-complete 
problems. Next, repeat the following sequence of instructions a few hundred 
times: 


Find a candidate II which might be NP-complete. Select an appropriate 
IT’ from the bag of NP-complete problems. Show that IT e¢ NP and IT’ < 11. 
Add ITI to the bag. 


An amount of cleverness is needed in selecting IT’ and finding a transforma- 
tion from I’ to II. By way of illustration we will demonstrate such a reduction 
in the proof of the next theorem. For a more complete treatment of Cook’s 
theorem and the reductions following from it, see (in increasing level of 
scope) Reingold, Nievergelt, and Deo [1977], Aho, Hopcroft, and Ullman 
[1974], and Garey and Johnson [1978]. 

To illustrate the technique of reduction, we present the following result. 


Theorem 2.1 (Poljak [1974]). (i) STABLE SET < STABLE SET 
ON TRIANGLE-FREE GRAPHS; 
(ii) STABLE SET < GRAPH COLORING. 


Proof. (i) Let G be an undirected graph with n vertices and e edges. 
The idea of our proof will be to construct from G a certain triangle-free graph 
H with the property that knowing a(H) will immediately give us a(G). Sub- 
divide each edge of G into a path of length 3; call the resulting graph H. 
Clearly, H is a triangle-free graph with n + 2e vertices and 3e edges. Also, H 
can be constructed from G in O(n + e) steps. Finally, since a(H) = «(G) + e, 
a deterministic polynomial time algorithm which solves for a(H) yields a 
solution to «(G). 

Gi) Let G be an undirected graph and construct H as in part (i). Next we 
construct H’ from H as follows. The vertices of H’ correspond to the edges 
of H, and we connect two vertices of H’ if their corresponding edges in H do 
not share a common vertex. This construction can be easily carried out in 
O(e’) steps. Since H is triangle-free, y(H’) =(2e + n)-—a(H) =e +n 
— a(G). Thus, «(G) can be determined from y(H’). 


Since it is well known that STABLE SET is NP-complete, we obtain the 
following lesser known result. 
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Corollary 2.2. STABLE SET ON TRIANGLE-FREE GRAPHS is 
NP-complete. 


A graph theoretic or other type of problem II which is normally hard to 
solve in the general case may have an efficient solution if the input domain is 
suitably restricted. The HAMILTONIAN CIRCUIT problem, for example, 
is trivial if the only graphs considered are trees. However, we have seen that 
restricting the STABLE SET problem to triangle-free graphs is not suf- 
ficient to allow fast calculation (until someone proves that P = NP). Re- 
search has found interesting families ¥ of graphs for which certain hard 
problems I when restricted to ¥ are nontrivial and tractable (ie., in P). In 
this book we will consider this situation for various families of perfect graphs 
and some not so perfect graphs. A more perplexing topic currently under 
investigation by many complexity theorists is that of finding and under- 
standing the cause of the boundary between the tractability and intractability 
of various problems IT. 

One final note: Our definition of complexity suppressed one fundamental 
point. An implementation of an algorithm is always taken relative to some 
specified type of machine. As an underlying assumption throughout this 
book we will take the random access machine (RAM), introduced by Cook 
and Reckhow [1973], as our model of computation. The RAM is an abstrac- 
tion of a general-purpose digital computer in which each storage cell has a 
unique address, allowing it to perform in one computational step an access 
to any cell, an arithmetic or Boolean operation, or a comparison. A computa- 
tion is performed sequentially by a RAM, one step at a time. The theory of 
NP-complete problems is usually formulated using the Turing machine 
model rather than the RAM. This presents no difficulty, however, since any 
RAM can be simulated on a deterministic Turing machine with only a 
polynomial increase in running time. 


Summary 


Besides providing a basis for comparing algorithms which solve the same 
problem, algorithmic analysis has other practical uses. Most importantly, it 
affords us the opportunity to know in advance of the computation an estimate 
or a bound on the storage and run time requirements, Such advance know- 
ledge would be essential when designing a computer system for a manned 
spacecraft in which the ability to calculate trajectories and fire the guidance 
rockets appropriately within tight constraints had better be guaranteed. 
Even in less urgent situations, having advanced estimates allows a program- 
mer to set job card limits to abort those runs which exceed the expected 
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bounds and hence probably contain errors, and to avoid aborting correct 
programs. Also such estimates are needed by the person who must decide 
whether or not it is worthwhile spending the necessary funds on computer 
time to carry out a certain (very large) computation. 


2. Data Structures 


As the name suggests, data structures provide a systematic framework in 
which the variables being processed (both input and internal) can be organ- 
ized. Data structures are really mathematical objects, but we will usually 
refer to their computer implementations by the same names. The most 
familiar data structure is the array, which is used in conjunction with sub- 
scripted variables. A 0-dimensional array is a single variable or storage 
location. A d-dimensional array can be defined recursively as a finite sequence 
of (d — 1)-dimensional arrays all of the same size. A vector is usually stored 
as a 1-dimensional array and a matrix as a 2-dimensional array. It is generally 
accepted that the entries of an array must be homogeneous (i.e., all of the 
same type and all requiring the same amount of space). 

The main feature of an array is its indexing capability. The subscripts 
should uniquely determine the location of each data item. The entries of an 
array are stored consecutively, and an addressing scheme using multipliers 
allows access to any entry in a constant amount of time, independent of the 
size of the array, on a random access machine. Thus, a query of the form 
“Is As 1. > 0?” can be executed in essentially one step. 

For those unfamiliar with the use of multipliers, the technique will be 
illustrated for an m, x m, matrix A. Let us assume that the entries of A are 
stored sequentially in locations of size s in the order A,,1, Ay,2,---, Ay,mys 
Ay t, Aa,as -++5 Adige «++ Ams, 12 Amy.29 ©++s Amim; (TOwW-major ordering). 
Then the space used by each row of A equals m2 s. Now A; ; could be accessed 
by starting at A, ,, jumping down i — 1 rows, and then moving over j — 1 
columns. Thus, if B = ADDRESS(A, _,), then we have the formula 


ADDRESS(A,, ) = B + (i — lms + (j — 1s. 


An analogous formula can be obtained for column-major ordering. This 
idea easily extends to d-dimensional arrays (Exercise 14). 

A list is a data structure which consists of homogeneous records which are 
linked together in a linear fashion. Each record will contain one field or more 
of data and one field or more of pointers. Figure 2.2 shows two singly linked 
lists; each record has a single forward pointer. Unlike an array, in which the 
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COURANT 
Loy 22 | e140 | 
COLUMBIA 


Lej—> 212 | o> 280] e4 


Figure 2.2. Two singly linked lists. 


data is stored sequentially in memory, the records of a list can be scattered 
throughout memory. The pointers maintain law and order. This allows the 
flexibility of changing the size of the data structure, inserting and deleting 
items, by simply changing the values of a few pointers rather than shifting 
large blocks of data. An implementation of our examples is given in Figure 
2.3. It uses two arrays and two single variables. The A is a special symbol 
indicating undefined. The list COURANT can be printed out by the following 
program: 


begin 
P — COURANT; 
while P 4A 
print DATA(?); 
P — POINTER(?P);; 
end 


This is an example of scanning a list. Scanning takes time proportional to 
the length of the list. 

Two special types of lists should be mentioned here because of their use- 
fulness in computer science. A stack is a list in which we are only permitted to 
insert and delete elements at one end, called the top of the stack. A queue 1s a 
list in which we are only permitted to insert at one end, called the tail of the 
queue, and delete from the other end, called the head of the queue. 


courant : [3 ] 
COLUMBIA ! 


5 6 7 8 
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Figure 2.3. An implementation of the lists COURANT and COLUMBIA using arrays. (In 
what year was Columbia founded?) 
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Let G = (V, E) be a graph whose vertices have been (arbitrarily) ordered 
V1, 02,---)0,. The adjacency matrix M = (m, ;) of Gis ann x n matrix with 
entries 


es 0 if 0,0, € E, 
‘i UL if njvjeE 


(see Figure 2.4b). By definition, the main diagonal of M is all zeros, and M is 
symmetric about the main diagonal if and only if G is an undirected graph. 
If M is stored in a computer as a 2-dimensional array, then only one step 
(more precisely O(1) time) is required for the statements “Is v;v;¢ E?” or 
“Erase the edge v;v,.” An instruction such as “mark each vertex which is 
adjacent to v,” requires scanning the entire column j and hence takes n 
steps. Similarly, “mark each edge” takes n* steps. The space requirement for 
the array representation is O(n”). A graph whose edges are weighted can be 
represented in the same fashion. In this more general case m,_; will equal the 
weight of v,v;; a nonedge will have weight either zero or infinity depending 
upon the application. 
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Figure 2.4. (a) The graph G. (b) The adjacency matrix of G. (c) The adjacency lists of G. 
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Some of the performance figures above can be improved upon when the 
density of M is low. We use the term sparse to indicate that |E} < n?, ie., 
the number of edges is much less than n?. One of the most talked about 
classes of sparse graphs are the planar graphs for which Euler proved that 
JE < 3n- 6. 


The Adjacency Lists of a Graph 


For each vertex v; of G we create a list Adj(v,) containing those vertices 
adjacent to v;. The adjacency lists are not necessarily sorted although one 
might wish them to be (see Figure 2.4c). The space requirement for the 
adjacency list representation of a graph with n vertices and e edges is 


U 


o( [i+ aa) = O(n + e), 


where d; denotes the degree of v, (see Figure 2.5). Thus, from storage con- 
siderations, it is usually more advantageous to use adjacency lists than the 
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Figure 2.5. Two implementations of Figure 2.4c. (a) An implementation of the adjacency 
sets of G as linked lists. (b) An implementation of the adjacency sets of G in sequential storage. 
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Table 2.2 


Some typical graph operations and their complexity with respect to three data structures“ 


Adjacency matrix Adjacency sets Adjacency sets 
stored as an array stored as lists stored sequentially 

Is vjv; an edge? oily O(d,)* O(d,)* 

Mark each vertex O(n) O(d;) O(d,) 

which is adjacent to »; 

Mark each edge O(n’) Ole) Ole) 

Add an edge 0,0; Ol) O(1)** O(e) 

Erase an edge u,v; O(ly O(d))* O(e) 


“If the adjacency sets are sorted, then the starred entries can be reduced to O(log 4d;) 
using a binary search, but the double starred entry will increase to O(d,). 


adjacency matrix to store a sparse graph. Often, it is also advantageous from 
time considerations to store a sparse graph using adjacency lists. For example, 
the instruction “mark each vertex which is adjacent to v,;” requires scanning 
the list Adj(v;) and hence takes d; steps. Similarly, “mark each edge” takes 
O(e) steps using adjacency lists, a substantial saving over the adjacency 
matrix for a sparse graph. However, erasing an edge is more complex with 
lists than with the matrix (see Table 2.2). Thus there is no representation of a 
graph that is best for all operations and processes. Since the selection of a 
particular data structure can noticeably affect the speed and efficiency of an 
algorithm, decisions about the representation must incorporate a knowledge 
of the algorithms to be applied. Conversely, the choice of an algorithm may 
depend on how the data is initially given. For example, an algorithm to set up 
the adjacency lists of a sparse graph will take longer if we are initially given 
its adjacency matrix as ann x n array rather than as a collection of ordered 
pairs representing the edges. 

A graph problem is said to be linear in the size of the graph, or simply 
linear, if it has an algorithm which can be implemented to run in O(n + e) 
steps on a graph with n vertices and e edges. This is usually the best that one 
could expect for a graph problem. By a careful choice of algorithm and data 
structure a number of simple problems can be solved in linear time; these 
include testing for connectivity (Section 2.3), biconnectivity (Exercise 5), and 
planarity (Table 2.1). We will illustrate this on the problem of converting the 
adjacency lists of a graph into sorted adjacency lists. 

It is by now a well-known fact that any algorithm which correctly sorts 
a set of k numbers using comparisons will require at least k log k compari- 
sons both in the worst case and in the average case.* Furthermore, many 


* All logarithms will be base 2. 
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O(k log k)-time algorithms for sorting by comparisons are available: HEAP- 
SORT, BINARY INSERTION, MERGESORT, etc. This might suggest 
that sorting the adjacency list of v; requires d; log d; steps, so that sorting 
all the adjacency lists would take £?_, d; log d; steps, which is superlinear, 
i.e., greater than O(n + e). As an alternative to comparison sorting, Adj(v,) 
could be put into order using a radix or bucket sort. This method takes 
O(n + d;) moves and is executed as follows: 


1. Initialize bit vector: (b,, b2,...,5,> — <0,0,..., 0) 
2. Scan Adj(v;) assigning: 6; — 1 for each v; € Adj(v;) 
3. Set SortedAdj(v,) — @ : 
4. Scan bit vector: for j — | ton do 
if b; = 1 then CONCATENATE 1; to SortedAdj(v;) 


If this were done for all adjacency sets, it would require O(n”) steps which 
is superlinear for sparse graphs. Happily, there is yet another method for 
ordering the adjacency lists, which turns out to be linear. It is conceptually 
very simple and differs from the above in that the SortedAdj(v,) are not 
created separately, but rather, simultaneously. 


Algorithm 2.1. Sorting the adjacency lists of a graph. 


Input: The unsorted adjacency lists of a graph G = (V, E) whose vertices 
are numbered v,, v2,..., v,- 

Output: The sorted adjacency lists of the reversal G~! = (V, E~*). (If G is 
undirected, then G = G~!; otherwise run the algorithm a second time on 
G"') 

Method: The algorithm is as follows: 


begin 
1 for i — | ton do SortedAdj(v,) — empty list; 
2 fori — 1 tondo 
3. for each v; € Adj(v;) do 
4 CONCATENATE 2; to SortedAdj(v,); 
end 


Theorem 2.3. Algorithm 2.1 runs in O(n + e) time. 


Proof. Line 1 is a loop which takes O(n) steps. Concatenation is indepen- 
dent of the length of a list provided that a pointing variable is used to re- 
member the address of the end of the list. Thus line 4 takes O(1) steps, and the 
loop 3-4 takes O(d;) steps. Therefore, the nested loops 2—4 require a total of 
y7_, O(d,) = O(e) steps, which proves the theorem. | 


The usual implementation of adjacency sets as linked lists is illustrated in 
Figure 2.5a. There is an alternate way of storing the adjacency sets when no 
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inserting or deleting is anticipated. Under these circumstances sequential 
storage can be used to eliminate the links that were present in the list repre- 
sentation and thus save space. In both implementations HEAD(i) points to 
the first member of Adj(v,), but Adj(v;) is now stored in consecutive locations 
DATA(HEAD()), ..., DATACHEAD(i) + DEGREE(i) — 1) (see Figure 
2.5b) and Exercise 9). 

For further reading on data structures and their uses see Knuth [1969], 
Aho, Hopcroft, and Ullman [1974], Horowitz and Sahni [1976], Lewis and 
Smith [1976], Wirth [1976], Goodman and Hedetniemi [1977], Reingold, 
Nievergelt, and Deo [1977], and Gotleib and Gotleib [1978]. 


3. How to Explore a Graph 


In designing algorithms we frequently require a mechanism for exploring 
the vertices and edges of a graph. Having the adjacency sets at hand allows 
us to repeatedly pass from a vertex to one of its neighbors and thus “walk” 
through the graph. Typically, in the midst of such a searching algorithm, some 
of the vertices will have been visited, the remainder not yet visited. A decision 
will have to be made as to which vertex x is being visited next. Since, in 
general, there will be many eligible candidates for x, we may want to es- 
tablish some sort of priority among them. 

Two criteria of priority which prove to be especially useful in exploring a 
graph are discussed in this section. They are depth-first search (DFS) and 
breadth-first search (BFS). In both methods each edge is traversed exactly 
once in the forward and reverse directions and each vertex is visited. By 
examining a graph in such a structured way, some algorithms become 
easier to understand and faster to execute. The choice of which method to 
use will often affect the efficiency of the algorithm. Thus, simply selecting a 
clever data structure is not sufficient to insure a good implementation. A 
carefully chosen search technique is also needed. 


Depth-First Search 


In DFS we select and visit a vertex a, then visit a vertex b adjacent to a, 
continuing with a vertex c adjacent to b (but different from a), followed by an 
“unvisited” d adjacent to c, and so forth. As we go deeper and deeper into 
the graph, we will eventually visit a vertex y with no unvisited neighbors; 
when this happens, we return to the vertex x immediately preceeding y in the 
search and revisit x. Note that if G is a connected undirected graph, then 
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procedure DFSEARCH(z): 

begin 
1. mark v “visited”; i - i + 1; DFSNUMBER(z) < 3; 
2. for each w € Adj(v) do 
3. if wis marked “unvisited”’ then 


begin 
4. add the edge vw to T; FATHER(») « 0; 
5. DFSEARCH(w); 

end 


end 


Figure 2.6. Depth-first search. 


each vertex will be visited and every edge will be explored once in both 
directions. If G is not connected, then such a search is carried out for each 
connected component of G. 

A depth-first search of an undirected graph G = (V, E) partitions the 
edge set into two classes T and B where T comprises a spanning forest of G 
with one spanning tree for each component of G. The edge xy is placed into 
T if vertex y was visited for the first time immediately following a visit to x. 
In this case x is called the father of y and y is the son of x. The origin of this 
male-dominated nomenclature appears to be biblical. The edges in T are 
called tree edges. The remaining edges, called back edges, are placed into B; 
they are also called fronds by an(n) arborist graph theorist. If G is connected 
then (V, T) is called a depth-first spanning tree. We consider each tree of 
the depth-first spanning forest to be rooted at the vertex at which the DFS of 
that tree was begun. 

An algorithm for depth-first search is given below. 


Algorithm 2.2. Depth-first search of a graph. 


Input: An undirected graph G = (V, E) represented by adjacency sets 
Adj(v), for ve V. 
Output: A partition of E into a set T of tree edges and a set B of back edges. 
Method: All vertices are initially marked “unvisited.” The procedure 
DFSEARCH in Figure 2.6 is used recursively. All edges in E not placed into 
T are assumed to be in B. In addition, the vertices are numbered from | ton 
according to the order in which they are first visited; DFSNUMBER(v) 
denotes this number for a vertex v. The algorithm is as follows: 

begin 
6. initialize: T<- @;i< 0; 
7, for all ve V do mark v “unvisited”’; 
8. while there exists v € V marked “unvisited” do 


9. DFSEARCH(y); 
end 
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In general a graph may have many depth-first spanning forests. Indeed 
there is quite a bit of freedom in choosing the vertices in lines 2 and 8. None- 
theless, a depth-first spanning forest T has some important and useful 
properties, which we now state. 


(D1) If v is a proper ancestor of w in T, then DFSNUMBER(v) < 
DFSNUMBER(w). 

(D2) For every edge of G, whether tree or back edge, one of its endpoints 
is an ancestor of the other endpoint, that is, there are no “cross edges.” 

We leave the proof of properties (D1) and (D2) as an exercise. 

DFSEARCH(v) is an example of a recursive procedure, that is, it calls 
itself. Such a procedure is implemented using a stack. When a call to itself is 
made, the current values of all variables local to the procedure and the line 
of the procedure which made the call are stored at the top of the stack. In this 
way when control is returned the computation can continue where it had left 
off. Some computer languages, like ALGOL, PL/I, PASCAL, and SETL, allow 
recursive subroutines and set up the stack automatically for you. Other 
languages, like FORTRAN, COBOL, Or BASIC, do not have this feature, so that the 
programmer must set up his own stack to simulate the recursion. 


Breadth-First Search 


In BFS we select a vertex and put it on an initially empty queue of vertices 
to be visited. We repeatedly remove the vertex x at the head of the queue and 
then place onto the queue all vertices adjacent to x which have never been 
enqueued. As in the case of depth-first search, BFS is carried out once for 
each connected component of the graph. However, in BFS each vertex is 
visited only once (and is thus exhausted, having produced all its offspring in 
one visit). 

A breadth-first search of an undirected graph G = (V, E) also partitions 
the edge set into two classes: the tree edges in T and the back edges in B. Here 
an edge xy is placed into T if vertex y is enqueued during the visit to x. The 
(partial) subgraph (V, T) is called a breadth-first spanning forest. 

An algorithm for breadth-first search is given below. 


Algorithm 2.3. Breadth-first search of a graph. 


Input: An undirected graph G = (V, E) represented by adjacency sets 
Adj(v), for ve V. 

Output: A partition of E into a set T of tree edges and a set B of back edges. 
Method: All vertices are initially marked “never enqueued.” The procedure 
BFSEARCH in Figure 2.7 is used to visit a vertex. All edges in E not placed 
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procedure BFSEARCH(x): 
begin 
1. i¢ i+ 1; BFSNUMBER(x) < i; 
2. for each y € Adj(x) do 
3. if y is marked “never enqueued”’ then 
begin 
4. add the edge xy to 7; FATHER()) < x; 
5. add y to Q; mark y “enqueued”’; 
end 
end 


Figure 2.7. Breadth-first search. 


into T are assumed to be in B. An array BFSNUMBER records the order in 
which the vertices are enqueued and visited. The algorithm is as follows: 


begin 
6. initialize: T<— ©; Q — empty queue; i « 0; 
7. for all v € V do mark v “never enqueued”’; 
8. while Q is empty and there exists v € V marked “‘never enqueued” 


9. add v to Q; mark v “*enqueued”’; 
10. while Q is nonempty 
I. x « head of Q;0<- Q — x; 
12. BFSEARCH(x); 
end 
end 
end 


Let T be a breadth-first spanning forest of an undirected graph G = (V, E). 
As was the case for DFS, a graph may have many breadth-first spanning 
forests. The level (in T) of a vertex v is defined inductively: 


0, if v is a root of a tree in T 


LEVEL(v) = 
(2) i + LEVEL(FATHER(v)), otherwise. 


A breadth-first spanning forest T satisfies the following properties. 


(B1) If v is a proper ancestor of w in T, then BFSNUMBER(v) < 
BFSNUMBER(y). 

(B2) Every edge of G, whether tree or back edge, connects two vertices 
whose level in T differs by at most 1. 

(B3) Ifvisa vertex in the connected component of G whose root in T is r, 
then the level of v equals the length of the shortest path from r to v in G. 


In Section 4.3 we will discuss a variant of the process described here, called 
lexicographic breadth-first search, in which the vertices of a given level are not 
searched in the same order as they are enqueued, but rather according to a 
priority which depends on their ancestors. 
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implementation and Complexity 


Let G = (V, E) be a graph. Both Algorithms 2.2 and 2.3 can be imple- 
mented to run in time and space proportional to |V| + |£|. Such an imple- 
mentation is said to be linear in the size of G. This is usually the best that one 
can expect from a graph algorithm, since it is reasonable to assume each 
vertex and each edge must be processed. Let us describe in detail a linear 
implementation of Algorithm 2.2 and leave Algorithm 2.3 as an exercise. 

The adjacency sets of G can be stored either as singly linked lists or by 
using sequential allocation*; thus, the input can be entered in O(|V| + |E|) 
time and space. A Boolean array VISITED of size | V| can serve to mark each 
vertex v unvisited if VISITED(v) = 0 and visited if VISITED(v) = 1. Thus, 
line 7 of Algorithm 2.2 can be executed in O(|V|) time, and the tests in lines 
3 and 8 can be done in constant time. The set T can be a singly linked list, 
while FATHER and DFSNUMBER will be arrays of size |V|. Hence 
statements 1, 4-6, and 9 can each be done in constant time. Now comes the 
crucial part of the complexity analysis. Statement 8 requires a pointing 
variable which will scan, or run through, all the vertices exactly once. That is, 
when this pointer finds an unvisited vertex, the pointer’s value will be saved, 
so that the next time statement 8 is required the search for an unvisited 
vertex can resume at the spot where it had last left off (rather than starting at 
the beginning of V each time). Therefore, the total number of operations 
summed over all executions of statement 8 is proportional to |V |. Exactly 
the same technique is used in statement 2 to scan Adj(v) which, together with 
our previous comments, implies that the entire procedure DFSEARCH(v) 
takes O(|Adj(v)|) time. Finally, the procedure is called once for each vertex, 
so the total time (and space) complexity of our implementation is 


OV |) + 2, OI Adi(o) 1), 


which equals O(|V| + |E|). 

As we mentioned in the opening paragraphs of this section, one search 
technique may be preferable over another, that is, it may give us a more 
efficient implementation. We list some instances of problems for which DFS 
and BFS are most effective, respectively. 


DFS—planarity testing; certain connectivity related problems (bicon- 
nectivity, triconnectivity); topological sorting; testing for cycles in an oriented 
graph. 


* If inserting or deleting of edges were required in the algorithm, then sequential allocation 
would not be advisable. 
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BFS —shortest-path problems; testing for chordless cycles (Sections 4.3 
and 4.4); network flow problems. 


In the next section we will discuss one of these problems—topological 
sorting. Upon completing that section the reader will have been exposed to 
all the algorithmic tools needed for the remainder of the book. For additional 
reading in this area see Aho, Hopcroft, and Ullman [1974], Goodman and 
Hedetniemi [1977], and Reingold, Nievergelt, and Deo [1977]. 


4. Transitive Tournaments and Topological Sorting 


Let F be an orientation of the complete graph K,, on n vertices. Each edge 
xy of F may be regarded as the outcome of a contest between the vertices x 
and y, where x was the loser and y the winner. We call F a transitive tourna- 
ment if, for all triples of vertices, 


xyeF and yzeF implies xzeF. (1) 


Condition (1) simply says that F has no 3-cycles. A stronger statement can 
be made. 


Theorem 2.4. Let F be an orientation of the complete graph K,. The 
following statements are equivalent. 


(i) F is a transitive tournament. 
(ii) F is acyclic. 


Moreover, the vertices can be linearly ordered [0,, v2,..., v,] such that 
(ill) _ v; has in-degree i — 1 in F, for all i, and 
(iv) v,v;¢F if and only if i <j. 


This linear ordering of the vertices is unique. Figure 2.8 shows a transitive 
tournament and the linear ordering of its vertices. 


Proof. (i) > (ii) Since F is transitive, it has no 3-cycle. Suppose F has an 
l-cycle (1 > 3) where / is smallest possible. But this /-cycle has a chord which 
shortcuts it, producing a cycle of shorter length and thus contradicting the 
minimality of I: Hence, F is acyclic. 

(ii) > (iii) If F is acyclic, then it has a sink (a vertex of out-degree zero). 
Call the sink v,. Clearly v, has in-degree n — 1. Deleting v, from the graph, 
we obtain a smaller acyclic oriented graph, and the conclusion follows by 
induction. 
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Figure 2.8. A transitive tournament. 


(iii) > (iv) By induction. 
(iv) > (i) Obvious. 


This theorem provides us with a linear time algorithm for recognizing 
transitive tournaments. First, calculate the in-degree of each vertex; then, 
using a Boolean vector, verify that there are no duplicates among the in- 
degrees. The technique of recognizing a class of graphs solely on the basis of 
the degrees of their vertices will be seen again when we study threshold graphs 
(Chapter 10) and split graphs (Chapter 6). 

A slightly more general problem than recognizing transitive tournaments 
is that of topologically sorting an arbitrary acyclic oriented graph G = (V, F). 
What we seek is a linear ordering of the vertices [v,, v2, ..., v,] which is 
consistent with the edges of G; that is, 


vjyvjeF >i<j (for all i, j). (2) 


An ordering which satisfies (2) is called a topological sorting of G. If G had a 
cycle, then a topological sorting would clearly be impossible. Why? But, if 
G is acyclic, then it is always possible. One method for finding an ordering 
satisfying (2) is the following: 


forj —|V| to 1 step —1 
Locate a sink v of the remaining graph and call it v;; (3) 
Delete v and all edges incident on v from the graph; 

next j; 


The correctness of this method is left as an exercise. In practice, we can 
implement (3) without actually deleting anything from our data structures. 
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Rather, we employ a depth-first search and some clever labeling. The 
algorithm is presented below. 


Algorithm 2.4. Topological sorting. 


Input: An acyclic oriented graph G = (V, F) stored as adjacency lists. 
Output: A DFS numbering of the vertices called DFSNUMBER and a 
topological sort numbering of the vertices called TSNUMBER. The algo- 
rithm also tests to make sure that G is acyclic. 

Method: To find the jth vertex of the desired ordering, the depth-first search 
procedure TOPSORT in Figure 2.9 locates a vertex v all of whose successors 
in G have already been searched and numbered and are therefore considered 
as having been deleted. This vertex v is then numbered. The entire algorithm 
is as follows: 


begin 
for each x e V do 
DFSNUMBER(x) « 0; 
TSNUMBER(x) < 0:; 
JVI; 
iQ; 
for each x € V do 
if DFSNUMBER(x) = 0 then 
TOPSORT(x); 
end 


Algorithm 2.4 is illustrated in an example in Appendix C. 


procedure TOPSORT(v): 
iei¢+l; 
DFSNUMBER(:) < i; 
for all w & Adj(v) do 
begin 
if DFSNUMBER(w) = 0 then 
TOPSORT(w); 
else if TSNUMBER(w) = 0 then 
“G is not acyclic”; 
end 
comment: We now label v with a value smaller than 
the value assigned to any descendant. 
TSNUMBER(2) < /; 
Jeoj-}; 
return 


Figure 2.9. 


Exercises 45 
EXERCISES 


1. (a) Show that a spanning tree of the complete graph K, is either a 
depth-first spanning tree or a breadth-first spanning tree. 

(b) Find a spanning tree of the complete graph K, which is neither a 
depth-first nor a breadth-first spanning tree. 
2. Modify the DFS and BFS Algorithms 2.2 and 2.3 to count the number of 
connected components of an undirected graph G. 
3. Prove properties (D1) and (D2) for any depth-first search spanning 
forest T. 
4. A vertex x is an articulation vertex of G if deleting x and all edges incident 
on it increases the number of connected components. Let G be a connected 
undirected graph, and let T be a DFS spanning tree of G. Prove that a vertex 
x is an articulation vertex of G if and only if one of the following holds: 

(i) xis the root of T, and x has more than one son; 

(ii) x is not the root of T, and for some son s of x there is no back edge 
between any descendent of s (including s itself) and a proper ancestor of x. 

Remark. A connected undirected graph G is biconnected (there are two 
vertex-disjoint paths between every pair of vertices) if and only if G has no 
articulation vertex. 


5 (Biconnectivity). Let Tbe a DFS spanning tree of an undirected graph G. 
Assume that the vertices are numbered consecutively as they are first visited 
during depth-first search, and let x(v) denote this number. For each vertex x, 
define 


LOW(x) = MIN{x(x), x(w)}, 


where w runs over all proper ancestors of x accessible from a son of x by 
going down some tree edges and then up one back edge. 

(a) Write a depth-first search algorithm which assigns the values x(x) 
and calculates the values LOW(x) for all vertices x. 

(b) Prove that your algorithm can run in O(|V]| + |E]) time for an 
arbitrary graph G = (V, E). 

(c) Show how your algorithm can detect articulation vertices using the 
function LOW. 
6. Describe an efficient implementation of Algorithm 2.3 and prove that it 
is linear in the size of the graph. 
7. Let S and T be subsets of the integers 1, 2, 3,..., n, and let A be a one- 
dimensional array of size n whose values have been initialized A(1) = 
A(2) = --- = A(n) = 0. Write subroutines which calculate S U T and S$ n T 
in time proportional to |S} +|T|. Assume that S and T are stored as 
(unordered) singly linked lists. (The answer appears in Appendix B.) 
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8. Let H =(V, F) be an acyclic oriented graph. A height function h is 
defined on the vertices inductively: 


if v is a sink, 
h(v) = : 
; + max{h(w)|w e Adj(v)} otherwise. 


Write a DFS algorithm which assigns a height function h to the vertices. 
Prove that your algorithm can be implemented to run in O(|V| + |F]) 
time. 

9. Let V = {1,2,...,n} and let E be a collection of m ordered pairs repre- 
senting the edges of a graph G = (V, E). Write a FORTRAN program which 
allocates sequential space in an array A of size m to store the adjacency sets 
of G, where Adj(1) is followed by Adj(2), etc. Let b; denote the location in A 
of the beginning of Adj(i), and let d; denote the out-degree of vertex i (i.e., the 
number of ordered pairs in which it is the first coordinate). You are permitted 
exactly two scans of E, one to calculate the out-degrees of the vertices and 
one to fill the array. For example, if 


E = {(4, 5), , 4), (6, 7), (3, 2), (4, 1), , 4), (8, 2), 
(7, 6), (2, 3), (2, 8), (9, 4), CL, 6), (4, 9), (6, 1), 
(5, 7), (4, 6), (4, 7), (7, 5), (6, 4), (7, 4)}; 


then the array A should look as indicated in Figure 2.10. Note that 
b; = 1 + Y d;. 


isi 


Adj(1) Adj(2) Adj(4) Adj(7) 


dj=2 d,=5 d,=3 b,=1 bg =6 6b, =16 
d,=2 dj=2 dg=1 b,=3 b=11 bg =19 
dy=1 do =3 dy=1 b,=5 be =13 bo = 20 


Figure 2.10. 


10. Using the data structure from Exercise 9 implement the algorithm 
from Exercise 8 and test it on some sample graphs. 

11. Using the data structure from Exercise 9 implement the algorithm 
from Exercise 5 to test some sample undirected graphs for biconnectivity. 
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12. Let U(n) be the set of all upper triangular, (0, 1)-valued n x n matrices. 
That is, ann x n matrix M = [m;,,] is in U(n) if 


0 i>j, 
n= 1 i=j, 
Oorl i<j. 


Show that U(n) forms a group under matrix multiplication over the two 
element field GF(2) and that the identity matrix J is the identity element of 
this group. (In GF(2): 0+0=141=0,04+1=1+0=1, 0-0= 
0-1=1-0=0,and1-1=1,) 

13. Let G = (V, F) be an acyclic, topologically sorted, oriented graph; i.e., 
its vertices have been renamed such that V = {1, 2,...,n} and 


ij¢ F implies i<j (i, je V). 
Clearly, this numbering implies that the adjacency matrix M(G) of G is upper 
triangular and is therefore in U(n) (see Exercise 12). Consider the subset 


Ug = (Me U(n)|m,; = 1,i <j > ijeF} 


consisting of those matrices in U(x) with nonzeros only in the positions 
determined by the nonzeros of M(G). 

(i) Show that the elements of U, can be ordered by set inclusion to form 
a complete, distributive lattice. 

(iit) Show that Ug is a subgroup of U(n) if and only if F is transitive (ie., 
a strict partial order). 
14. Let A be a d-dimensional array of size m, x mz Xx --- xX m,. Discuss 
how A may be stored in consecutive storage locations of size s in a manner 
similar to row-major or column-major ordering. Give a formula for obtaining 
the address of A; i... i4- 
15. In the proof of Theorem 2.1, show that the following claims are valid: 

(i) The transformation Gr H is O(n + e). 

Gi) a(H) = oG) +e. 

(iii) The transformation H +> H’ is O(e?). Can this be improved? 

(iv) y(H') =e +n — o(G). 
16. Prove the following: If G has n vertices, then y(G) < r if and only if 
a(G x K,) =r, where x denotes the Cartesian product. (The Cartesian 
product of two graphs G, = (V,, E,) and G, = (V,, E,) is the graph G = 
(V, x V,, E), where E = {((v, v2), (vj, v>))leither v; = v, and (v2, v,)E E, 
or v, = v, and (v,, v})€ E,} (Chvatal [1973, p. 326]). 
17. Using Exercise 16, show that GRAPH COLORING X STABLE SET. 
18. Prove that assigning a minimum coloring to a bipartite graph has 
complexity which is linear in the size of the graph. 
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19. Prove that STABLE SET restricted to bipartite graphs has com- 
plexity which is polynomial in the size of the graph. 

20. Prove that HAMILTONIAN CIRCUIT restricted to bipartite graphs 
is NP-complete. 

21. Ifa positive integer m can be stored in 1 + [log, m] space, show that 
the numbers 1, 2, 3,..., n can be stored in a total of O(n) space. 

22. Algorithms of and # run in n? and 2" steps, respectively, on an input 
of size n. 

(i) Ifcurrent computers can execute 10° steps/sec, what size input can be 
processed by each algorithm in one minute? In one hour? In one year? 

(ii) Suppose that by the time this book reaches your university library 
the computer industry has a technological breakthrough, which increases 
the speed of execution by 100-fold. What will be the corresponding increased 
capability of algorithms ./ and #? 
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CHAPTER 3 


Perfect Graphs 


1. The Star of the Show 


In this section we introduce the main character of the book—the perfect 
graph. He was “discovered” by Claude Berge, who has been his agent since 
the early 1960s. P.G. has appeared in such memorable works as “Farbung 
von Graphen, deren samtliche bzw. deren ungerade Kreise starr sind” and 
“Caractérisation des graphes non orientés dont on peut orienter les arrétes 
de maniére a obtenir le graphe d’une relation d’ordre.” Despite his seemingly 
assuming name, P.G. has mixed the highbrow glamorous life with an intense 
dedication to improving the plight of mankind. His feature role in “Perfect 
graphs and an application to optimizing municipal services” has won him 
admiration and respect around the globe. Traveling incognito, a further sign 
of his modesty, he has been spotted by fans disguised as a graph parfait or as 
a (banana) split graph in a local ice cream parlor. So, ladies and gentlemen, 
without further ado, the management proudly presents 


THE PERFECT GRAPH 


Let us recall the following parameters of an undirected graph, which were 
defined in Section 1.1. 

aA(G), the clique number of G: the size of the largest complete subgraph 
of G. 

x(G), the chromatic number of G: the fewest number of colors needed to 
properly color the vertices of G, or equivalently, the fewest number of stable 
sets needed to cover the vertices of G. 
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a(G), the stability number of G: the size of the largest stable set of G. 
k(G), the clique cover number of G: the fewest number of complete sub- 
graphs needed to cover the vertices of G. 


The intersection of a clique and a stable set of a graph G can be at most one 
vertex. Thus, for any graph G, 


o(G) < x(G) 
and 
a«(G) < k(G). 


These equalities are dual to one another since a(G) = w(G) and k(G) = 
XG). 

Let G = (V, E) be an undirected graph. The main purpose of this book is 
to study those graphs satisfying the properties 


(P;)  @(G,)= (G4) (forall Ac V) 
and 
(P,) oG,=KG,) (forallAc V). 


Such a graph is called perfect. It is clear by duality that a graph G satisfies 
(P,) if and only if its complement G satisfies (P,). A much stronger result was 
conjectured by Berge [1961], cultivated by Fulkerson [1969, 1971, 1972], 
and finally proven by Lovasz [1972a], namely, that (P,) and (P,) are equiv- 
alent. This has become known as the Perfect Graph theorem, which will be 
proved in the next section along with a third equivalent condition, due to 
Lovasz [1972b], 


(P;) wG,a(G,)>|A| (forall A V). 


In subsequent chapters it will be sufficient to show that a graph satisfies any 
(P;) in order to conclude that it is perfect, and a perfect graph will satisfy 
all properties (P;). 

A fourth characterization of perfect graphs, due to Chvatal [1975], will 
be discussed in Section 3.3, and we shall encounter still another formulation 
in the chapter on superperfect graphs. 

It is traditional to call a graph y-perfect if it satisfies (P,) and «-perfect if it 
satisfies (P,). The Perfect Graph theorem then states that a graph is y-perfect 
if and only if it is «-perfect. However, the equivalence of (P,) and (P,) fails 
for uncountable graphs. The interested reader may consult the following 
references on infinite perfect graphs: Hajnal and Suranyi [1958], Perles 
[1963], and Nash-Williams [1967], Baumgartner, Malitz, and Reinhardt 
[1970], Trotter [1971], and Wagon [1978]. 
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2. The Perfect Graph Theorem 


In this section we shall show the equivalence of properties (P,)~(P3). A 
key to the proof is that multiplication of the vertices of a graph, as defined 
below, preserves each of the properties (P;). 

Let G be an undirected graph with vertex x. The graph Go x is obtained 
from G by adding a new vertex x’ which is connected to all the neighbors of 
x. We leave it to the reader to prove the elementary property 


(Gox) —y=(G— y)ox for distinct vertices x and y. 


More generally, if x,, x2,..., x, are the vertices of G and h = (hy, hy,..., hy) 
is a vector of non-negative integers, then H = Gch is constructed by sub- 
stituting for each x; a stable set of h; vertices x}, ..., x? and joining x} with 
x; iff x, and x; are adjacent in G. We say that H is obtained from G by multi- 
plication of vertices. 


Remark. The definition allows h; = 0, in which case H includes no copy 
of x;. Thus, every induced subgraph of G can be obtained by multiplication 
of the appropriate (0, 1)-valued vector. 


Lemma 3.1 (Berge [1961]). Let H be obtained from G by multiplication 
of vertices. 


(i) If G satisfies (P,), then H satisfies (P,). 
(ii) If G satisfies (P,), then H satisfies (P,). 


Proof. The lemma is true if G has only one vertex. We shall assume that 
(i) and (ii) are true for all graphs with fewer vertices than G. Let H = Goh. 
If one of the coordinates of h equals zero, say h; = 0, then H can be obtained 
from G — x; by multiplication of vertices. But, if G satisfies (P,) [resp. (P2)], 
then G — x; also satisfies (P,) [resp. (P,)]. In this case the induction hypoth- 
esis implies (i) and (ii). 

Thus, we may assume that each coordinate h; > 1, and since H can be 
built up from a sequence of smaller multiplications (Exercise 2), it is sufficient 
to prove the result for H = Gox. Let x’ denote the added “copy” of x. 

Assume that G satisfies (P,). Since x and x’ are nonadjacent, w(G x) = 
a(G). Let G be colored using w(G) colors. Color x’ the same color as x. This 
will be a coloring of G o x in w(G o x) colors. Hence, G o x satisfies (i). 

Next assume that G satisfies (P,). We must show that a(G o x) = k(Go x). 
Let & be a clique cover of G with | #| = k(G) = a(G), and let K,, be the 
clique of # containing x. There are two cases. 
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Case 1: x is contained in a maximum stable set S of G, ie., |S| = a(G). In 
this case S U {x'} is a stable set of Go x, so 

a(G ox) = a(G) 4+ 1. 
Since X vu {{x'}} covers Go x, we have that 
kK(Gox) < KG) + 1 = oG) + 1 = Geox) < (Geox). 

Thus, «(G ° x) = k(Go x). 

Case 2: No maximum stable set of G contains x. In this case, 

a(G ox) = a(G). 


Since each clique of % intersects a maximum stable set exactly once, this is 
true in particular for K,. But x is not a member of any maximum stable set. 


Therefore, D = K, — {x} intersects each maximum stable set of G exactly 
once, so 


a(Gy_p) = &G) — 1. 
This implies that 
k(Gy—p) = «(Gy_p) = eG) — 1 = (Gex) — 1. 


Taking a clique cover of Gy_p of cardinality «(Go x) — 1 along with the 
extra clique D u {x’}, we obtain a cover of G o x. Therefore, 


k(G 0 x) = a(Go x). I 


Lemma 3.2 (Fulkerson [1971], Lovasz [1972b]). Let G be an undirected 
graph each of whose proper induced subgraphs satisfies (P,), and let H be 
obtained from G by multiplication of vertices. If G satisfies (P3), then H 
satisfies (P3). 


Proof. Let G satisfy (P3) and choose H to be a graph having the smallest 
possible number of vertices which can be obtained from G by multiplication 
of vertices but which fails to satisfy (P3) itself. Thus, 


oH )a(H) < |X|, (1) 


where X denotes the vertex set of H, yet (P3) does hold for each proper in- 
duced subgraph of H. 

As in the proof of the preceding lemma, we may assume that each vertex of 
G was multiplied by at least 1 and that some vertex u was multiplied by 
h > 2. Let U = {u', u?,..., u"} be the vertices of H corresponding to u. The 
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vertex u} plays a distinguished role in the proof. By the minimality of H, 
(P3) is satisfied by Hy _,:, which gives 
|X| —1=|X —u'| < o(Ay_y)o(Hy-) [by (P3)] 
< w(H)o(H) 
<|X|~-1 [by (1)]. 
Thus, equality holds throughout, and we can define 
p = (Hx_,:) = o(H), 
q= oC Hy — 1) = a(H), 
and 
pq = |X|—-1. (2) 


Since Hy _y is obtained from G — u by multiplication of vertices, Lemma 
3.1 implies that Hy _y satisfies (P,). Thus, Hy_y can be covered by a set of q 
complete subgraphs of H, say K,, K,,..., K,. We may assume that the K; 
are pairwise disjoint and that |K,| > |K.,| > --- > |K,|. Obviously, 


YIK I = 1X - U|=|X|—h=pq-—(h—-1) [by Q)].- 


~ 
ll 
_ 


Since | K;| < p, at most h — 1 of the K; fail to contribute p to the sum. Hence, 
|K,|=|K,|=---= |Kq-neil = p. 


Let H’ be the subgraph of H induced by X’ = K,U---U Kya. VU 
{u'}. Thus 


IX’|=pq-—h+I)+1<pq+1=|X| — [by()], (3) 

so by the minimality of H, 
o(H'\a(H’) = |X"| [by (P3)]. (4) 

But p = w(H) => o(H’), so 


a(H’) > |X'\/p — [by (4)] 
>q—-h+1 [by (3)]. 
Let S’ be a stable set of H’ of cardinality q — h + 2. Certainly u' eS’, for 
otherwise S’ would contain two vertices of a clique (by the definition of H’). 


Therefore, S = S’ U U isa stable set of H with qg + 1 vertices, contradicting 
the definition of g. | 
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Theorem 3.3 The Perfect Graph Theorem (Lovasz [1972b]). For an 
undirected graph G = (V, E), the following statements are equivalent: 


(P,)  — @(G4) = (G4) (for all A < V), 
(P,)  a(G4) = kK(G,) (for all A < V), 
(P3) cAG,)a(G4)> [Al (forall Ac V). 


Proof. We may assume that the theorem is true for ali graphs with fewer 
vertices than G. 


(P,) => (P;3). Suppose we can color G, in w(G ,) colors. Since there are at 
most «(G,) vertices of a given color it follows that w(G,)a(G,4) = |A|. 


(P3)=(P,). Let G = (V, E) satisfy (P3); then by induction each proper 
induced subgraph of G satisfies (P,)-(P3). It is sufficient to show that 
o(G) = x(G). 


If we had a stable set S of G such that w(Gy_s) < w(G), we could then paint 
S orange and paint G,_s in w(G) — 1 other colors, and we would have a(G) 
= x(G). 

Suppose Gy_,s has an w(G)-clique K(S) for every stable set S of G. Let F 
be the collection of all stable sets of G, and keep in mind that $ m K(S) = @. 
For each x; € V, let h; denote the number of cliques K(S) which contain x;. 
Let H = (X, F) be obtained from G by multiplying each x; by h;. On the one 
hand, by Lemma 3.2, 


oA H)a(H) = |X]. 


On the other hand, using some simple counting arguments we can easily 
show that 


|X| = ds 
= }IK(S)| = AGI, (5) 
Sef 
o(H) < aG), (6) 
o(H) = max ¥ fh, (7) 
TeS X;eT 
a max] YITa K(| (8) 
TeS\(SeF 


<|F|-1, (9) 
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which together imply that 
oH) < of GX|S| — 1) < |X, 


a contradiction.* 


(P,)<>(P3). By what we have already proved, we have the following 
implications: 


G satisfies (P,) <> G satisfies (P,) 
<> G satisfies (P;) <> G satisfies (P3). | 


Corollary 3.4. A graph G is perfect if and only if its complement G is 
perfect. 


Corollary 3.5. A graph G is perfect if and only if every graph H obtained 
from G by multiplication of vertices is perfect. 


Historical note. The equivalence of (P,) and (P,) was almost proved by 
Fulkerson. He heard the news of the success of Lovasz, who was not aware 
of Fulkerson’s work at that time, from a postcard sent by Berge. Fulkerson 
immediately returned to his previous results on pluperfection and, within a 
few hours, obtained his own proof. Such are the joys and sorrows of research. 
His consolation, to our benefit, was that in the process of his investigations, 
Fulkerson invented and developed the notion of antiblocking pairs of 
polyhedra, an idea which has become an important topic in the rapidly 
growing field of polyhedral combinatorics. 

Briefly, and in our terminology, Fulkerson had proved the following: 


Let .4@(G) be the collection of all graphs H which can be constructed from 
a graph G by multiplication of vertices. Then, H satisfies (P,) for all He. 4(G) 
if and only if H satisfies (P,) for all H € .4(G). 


* Equations (5)-(9) are justified as follows: 

(5) Consider the incidence matrix whose rows are indexed by the vertices x,,x.,...,X, and 
whose columns correspond to the cliques K(S) for Se “ Then, A; equals the number of non- 
zeros in row i, and | K(S)| equals the number of nonzeros in its corresponding column, which is 
by definition equal to w(G). 

(6) At most one ‘‘copy” of any vertex of G could be in a clique of H. 

(7) Ifa maximum stable set of H contains some of the ‘“‘copies”’ of x;, then it will contain all 
of the “copies.” 

(8) Restrict attention to those rows of the matrix pertinent to (5) which belong to elements 
of T. 

(9) |T a K(S)| < land|T K(T)| = 0. 


+ Polyhedral combinatorics deals with the interplay between concepts from combinatorics 
and mathematical programming. 
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Clearly, this result together with Lemma 3.1 would give a proof of the equival- 
ence of (P,) and (P,) for G. 


3. p-Critical and Partitionable Graphs’* 


An undirected graph G is called p-critical if it is minimally imperfect, that 
is, G is not perfect but every proper induced subgraph of G is a perfect graph. 
Such a graph, in particular, satisfies the inequalities 


a(G — x) = kK(G — x) and a@(G — x) = x(G — x) 
for all vertices x, where G — x denotes the resulting graph after deleting x. 
The following properties of p-critical graphs are easy consequences of the 
Perfect Graph theorem. 
Theorem 3.6. If G is a p-critical graph on n vertices, then 
n = a(G)a(G) + I, 
and for all vertices x of G, 
a(G) = K(G — x) and a(G) = 7(G — x). 


Proof. By Theorem 3.3, since G is p-critical we have n > a(G)@(G) and 
n—1<a(G — x)o(G — x) for all vertices x. Thus, 


n—1<a(G — x)w(G — x) < a(G)o(G) < 7. 
Hence, n — 1 = a(G)w(G), «(G) = a(G — x) = k(G — x), and 
o(G) = o(G — x) = x(G — x). | 
Let «, w > 2 be arbitrary integers. An undirected graph G on n vertices is 
called (a, w)-partitionable if n = aw + 1 and for all vertices x of G 
a= k(G — x), @ = 7(G — x). 


We have shown in Theorem 3.6 that every p-critical graph is (a, w)-partition- 
able with « = o(G) and wm = w(G). A more general result holds. 


Remark 3.7. After removing any vertex x of an («, w)-partitionable graph, 


the remaining graph has aw vertices, chromatic number «, and clique cover 
number «a. So an w-coloring of G — x will partition the vertices into w stable 
sets, one of which must be at least of size «. Similarly, a minimum clique 


* Sections 3.3-3.5 were written jointly with Mark Buckingham. 
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cover of G — x will partition the vertices into a cliques, one of which must 
be at least of size aw. 


Theorem 3.8. If G is an («, w)-partitionable graph, then « = a(G) and 
@ = o(G). 


Proof. Let G = (V, E) be (a, w)-partitionable. By Remark 3.7, a < a(G) 
and w < w(G). Conversely, take a maximum stable set S of G and let ye 
V — S. Then S is also a maximum stable set of G — y, so 


a(G) = |S| = a(G — y) <k(G— y) =a. 
Thus, «(G) < «. Similarly, o(G) < w. Therefore, « = «(G)andw = a(G). J 


Theorem 3.8 shows that the integers « and w for a partitionable graph are 
unique. Therefore, we shall simply use the term partitionable graph and 
assume that « = o(G)and w = w(G). The class of p-critical graphs is properly 
contained in the class of partitionable graphs which, in turn, is properly con- 
tained in the class of imperfect graphs (Exercise 10). 


Lemma 3.9. If G is a partitionable graph on n vertices, then the following 
conditions hold: 


G) Gcontainsa set ofn maximum cliques K,, K,,...,K,,that cover each 
vertex of G exactly w(G) times; 
(ii) G contains a set of n maximum stable sets S,, S,,..., S, that cover 


each vertex of G exactly «(G) times; and 
(ili) K;S; = © ifand only if i = j. 


Proof. Choose a maximum clique K of G and, for each x € K, choose a 
minimum clique cover #,, of G — x. By Remark 3.7, all of the members of 
KH, must be cliques of size w. Finally, let A be the n x n matrix whose first 
row is the characteristic vector of K and whose subsequent rows are the 
characteristic vectors of each of the cliques in #, for all x e K. (Note that the 
number of rows is 1 + aw = n.) 

Each vertex y ¢ K is covered once by #, for all x e K. Each vertex ze K 
is covered once by K and once by #, for all z # xe K. Therefore, every 
vector is covered w times. For each row a; of A we let K; be the clique whose 
characteristic vector is a;. We may express (i) by the matrix equation 1A = 1, 
where 1 is the row vector containing all ones. Condition (i) will be satisfied 
once we show that the K;, are distinct. 

For each i, pick a vertex ve K; and let Y denote a minimum stable set 
covering (coloring) of G — v. By Remark 3.7 and an easy counting exercise, 
there must be some stable set S;e Y such that K; 1 S; = @. Let b; be the 
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characteristic vector of S;, and let B denote the n x n matrix having rows b, 
fori = 1,...,n. Since 1-b’= a, we have 
1ABT = wI1B™ = wal = (n — 11. 


But a; b? = 0, so AB’ = J — I, where J is the matrix containing all ones 
and I is the identity matrix. This proves (iii). 

Finally, both A and B are nonsingular matrices since J — I is nonsingular. 
Thus, the K; are distinct and the S, are distinct. Furthermore, 


1B = 1BA"(A‘)"! = 1(J ~— D(A)! = (nx — 1)1(AT)“! 
=[(n — 1/o]i = al, 
which proves (ii). | 


The next result shows that all the maximum cliques and stable sets of G 
are among those in Lemma 3.9. 


Lemma 3.10. A partitionable graph G contains exactly n maximum 
cliques and n maximum stable sets. 


Proof. Let A and B be the matrices whose rows are the characteristic 
vectors of the cliques and stable sets, respectively, satisfying AB’ = J — I as 
specified in Lemma 3.9. Suppose that c is the characteristic vector of some 
maximum clique of G. We will show that ¢c is a row of A. 

We first observe that A~’ = w ‘J — B" since 

A(o@7'J — B') = w 'AJ — AB’ = J — ABT =I. 
A solution t to the equation tA = c will satisfy 
t= cA) = w~'eJ — cB’ = wm '(w1) — cB" = 1 — cB’. 
Therefore, t is a (0, 1)-valued vector. Also, 
t-17 = (1 — cB‘)-17 =n — acl" =n- aw = 1. 


Therefore, t is a unit vector. This implies that ¢ is a row of A. 
Similarly, every characteristic vector of a maximum stable set is a row of B. 


Theorem 3.11. Let G be an undirected graph on n vertices, and let 
a = a(G) and w = w(G). Then G is partitionable if and only if the following 
conditions hold: 


(ij) n=anm4+1; 
(ii) Ghas exactly n maximum cliques and n maximum stable sets; 
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(iii) every vertex of G is contained in exactly w maximum cliques and in 
exactly « maximum stable sets; 

(iv) each maximum clique intersects all but one maximum stable set and 
vice versa. 


Proof. (=>) This implication follows from Lemmas 3.9 and 3.10. 
(=) Following our previous notation, conditions (ii)-(iv) imply that 


AJ = JA = oJ, BJ = JB = oJ, AB’ = J —I, 


where A and Bare n x n matrices whose rows are the characteristic vectors 
of the maximum cliques and maximum stable sets, respectively. Let x; be a 
vertex of G and let hj be its corresponding column in A. Since 


A'B = B“'BA'B = B-'(J — DB = B '(aJ — B) 
=aa'J-I=J-] 


we obtain h;B = 1 — e;, where e; is the ith unit vector. Thus, h; designates w 
rows of B (ie., stable sets of G) which cover G — x,. Thus, ¥(G — x,) < a. 
By a similar argument, k(G — x;) < a for all x;. But since n — 1 = aw, we 
must have 7(G — x,;) = w and k(G — x,) = a. Therefore, G is partitionable. 


Corollary 3.12 (Padberg [1974]). If G is a p-critical graph, then 
conditions (i)—(iv) of Theorem 3.11 hold. 


Padberg’s investigation of the facial structure of polyhedra associated 
with (0, 1)-valued matrices first led him to a proof of Corollary 3.12. (We shall 
discuss some of Padberg’s work in Section 3.5.) The proof presented here, 
using only elementary linear algebra, is due to Bland, Huang, and Trotter 
[1979]. Additional results on p-critical graphs can be found in Section 3.6. 

The only p-critical graphs known are the chordless cycles of odd length 
and their complements. Figures 3.1 and 3.2 illustrate the conditions of 
Theorem 3.11 for the graphs C, and C,. 


K, = {1, 2}, Ka = {2,3}, Ks = {3,4}, Ka = {4, 5}, Ks = {5, 1} 
Sy = {3,5}, $2 = {1,4}, Ss = {2,5}, Sa = (1, 3}, Ss = (2, 4} 
{I} e Ky, Ks, 82,84; {2} € Ky, Ka, S53, Ss; 
4 3 (3}€ Kz, K3,8,,Sq; {4} Ky, Ky, S2, S855 
{5} € Ka, Ks, S1, Ss 
n=5, a(G/=2, wl(G/=2 


Figure 3.1. The graph Cs and its maximum clique and stable set structure as specified in 
Theorem 3.11. 
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K, = {1, 2,3}, K. = {2, 3,4}, Ks = (3,4, 5}, Ka = 14, 5, 6} 


7 2 Ks, = (5,6, 7}, Ke = {6,7, 1}, Ky = (7, 1,2} 
Sy) = 14,7), S2 = {1.5}, $3 = {2, 6}, S, = 13,7} 
Ss = {1,4}, S_ = {2,5}, 57 = {3, 6} 
6 3 


}€ Ky. Kg. K7,S2,S85: (2) Ky, Ka, Kz, Sa, Sos 
1€Ky.K2,K3,S4,5S7) {446 Kz, Ky, Ka. Sa, Ss: 
5 4 {5} K 3, Ka, Ks, 82.85: (616 Ka, Ks, Ko, $3, St: 
(ThE Ks, Ko. Ky, Sy. Sa 
n=T7 afG) =2 w(G)=3 


Figure 3.2. The graph C, and its maximum clique and stable set structure as specified in 
Theorem 3.11. 


4. A Polyhedral Characterization of Perfect Graphs 


Let A be an m x n matrix. We consider the two polyhedra 
P(A) = {x|Ax < 1, x > 0} 
and 


P,(A) = convex hull({x|x € P(A), x integral}), 


where x is an n-vector and 1 is the m-vector of all ones. Clearly P(A) © P(A), 
and for (0, 1)-valued matrices A having no zero column, P(A) and P,(A) 
are bounded and are within the unit hypercube in R”. An important example 
of such a matrix is the maximal cliques-versus-vertices incidence matrix of 
an undirected graph G. This is called the clique matrix if all the maximal 
cliques are included. The clique matrix of G is unique up to permutations of 
the rows and columns (see Figure 3.3). 

Let A be any m x n (0, 1)-valued matrix having no zero columns. The 
derived graph of A has n vertices v,, v2,..., v, corresponding to the columns 
of A, and an edge connecting v; and v; whenever the ith and jth columns of 


J 
A have a | in some row a,. Clearly every row of A forms a (not necessarily 


Figure 3.3. A graph and its clique matrix. 
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maximal) clique in its derived graph. Many matrices have the same derived 
graph. For example, if A is either the clique matrix or the edge incidence 
matrix of G, then the derived graph of A will be G. 


Lemma 3.13. Let G be an undirected graph, and let A be any (0, 1)-valued 
matrix having no zero column whose derived graph equals G. Then x is an 
extremum of P,(A) if and only if x is the characteristic vector of some stable 
set of G. 


Proof. If x is an extremum of P(A), then x must be integral, and since A 
is (0, 1)-valued without a zero column, x < 1. Thus, x is the characteristic 
vector of some set of vertices S. Suppose there exist vertices u and v of S that 
are connected in G; hence some row a, of A has a 1 in columns u and v. This 
yields a,* x > 2, yet Ax < 1. Therefore, S must be a stable set. 

Conversely, given that x is a characteristic vector of a stable set of G, 
certainly x € P,(A). Let x be expressed as a convex combination of some set 
of extrema {b”, b®, ..., b} of P,(A); that is, 


x, = ¥, 1=Fc%, Osc <t. 
i i 


Thus, if x, = 1, then b, = 1 for all i, and if x, = 0, then b, = 0 for all i. 
Therefore, x = b® and x is an extremum of P,(A). i 


Theorem 3.14 (Chvatal [1975]). Let A be the clique matrix of an undirect- 
ed graph G. Then G is perfect if and only if P,(A) = P(A). 

To prove the theorem we shall use a result from linear programming used 
by Edmonds [1965] and others: 


Lemma 3.15. Given bounded polyhedra S and T, where S has a finite 
number of extrema, 
S=T iff maxe'x = maxe'x (Ve, integral). 
subj xeS subj xeT 


Proof of Theorem 3.14. Assume that P;(A) = P(A). Let Gy be an induced 
subgraph of G, and let u denote the characteristic vector of U. We have, 


a(Gy) = maxux = maxux = miny'l. 
subj xe P7(A) subj Ax<1I,x2>0 subj yA>u, y20 


The first equality follows from the fact that maximums are always achiev- 
able at some extremum and the extrema of P,(A) correspond to stable sets 
(Lemma 3.13). The second equality follows from Lemma 3.15 setting ¢ = u, 
and the third equality comes from the duality theorem of linear programming. 
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Therefore, choose y > 0 such that )° y, = «(Gy) and u < yA. Denoting the 
jth column of A by a’, we obtain 
|Ul|= Yiuy< Vy-a’=y- dial <y-(@(Gy)l) = a(Gy)o(Gy). 
jeu jeu jeu 
Thus, by Theorem 3.3, G is perfect. 
Conversely, assume that G is perfect. For any integer vector c, form the 


graph H by multiplying the ith vertex of G by max (0, c,) for each i. By Lemma 
3.1, H is perfect. We have the following: 


a(H) = «a(G) The maximum weighted stable set of 
G given by ce. 
= maxe*x The maximum can always be found 
subj xe P(A) 


at an extremum, which corresponds 
to a stable set (Lemma 3.13). 


< maxe’x P,(A) S P(A). 
subjxe P(A) 
= miny-l Duality theorem. 


subj yA>c, y>0 


lA 


min y-1 The constraint set is smaller. 
subj yA>c, non-negative integral y 
=k (G) The minimum clique covering of G 
such that vertex i is covered c; 
times. The constraint yA > c, non- 
negative integral y, specifies such a 
covering. 
= k(H). Any clique of H corresponds to a 
clique of G, thus k(H) => k,(G); if 
vertex i of G is covered by c; 
cliques, then there are c; cliques in 
H, each covering a different copy of 
i, so k,(G) = k(H). 
But «(H) = k(H). Thus, 
maxe*x = maxe-x 
subj xe P;{A) subj xe P(A) 
and, by Lemma 3.15, P,(A) = P(A). I 
Remark. The first half of the proof of Theorem 3.14 still holds under a 
weakened hypothesis on A: 


If A is a (0, 1)-valued matrix having no zero column whose derived graph 
equals G, then P;(A) = P(A) implies that G is perfect. 
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5. A Polyhedral Characterization of p-Critical Graphs 


Manfred Padberg first discovered the properties shown in Section 3.3 of 
p-critical graphs while investigating the facial structure of the polyhedra 
P(A) for general (0, 1)-valued matrices A. In doing so, he also discovered a 
polyhedral characterization of p-critical graphs. In Padberg [1973, 1974], he 
used the results of Lovasz and Chvatal to produce these results. In a later 
work, Padberg [1976b], he developed a more general approach, which 
enabled him to prove the same results directly and to prove the theorems of 
Lovasz and Chvatal in a different manner. 

The matrix A is said to be perfect if P(A) is integral, that is, P(A) has only 
integer extrema: P,(A) = P(A). A is said to be almost perfect if P(A) is 
almost integral, that is, (i) P(A) # P(A) (P(A) has at least one nonintegral 
extremum), and (ii) the polyhedra P(A) = P(A) 1 {xe R"|x; = 0} are all 
integral, j = 1,2,...,n. 

For the remainder of this section, A will always denote an m x n (0, 1)- 
valued matrix having no zero column, and P, P,, and P; will denote P(A), 
P(A), and P(A), respectively. 

Padberg’s results, although not stated in the following manner, include the 
following six theorems. 


Theorem 3.16. If A is perfect, then A is an augmented clique matrix of its 
derived graph, that is, A is the clique matrix possibly augmented with some 
redundant rows corresponding to nonmaximal cliques. 


Let J denote the matrix of all ones and I the identity matrix. We say that A 
contains the n x n submatrix J — I if some permutation of J — I occurs as 
ann x n submatrix of A. 


Theorem 3.17. If A is almost perfect, then either (i) A is an augmented 
clique matrix of its derived graph or (ii) A contains the n x n submatrix 
J—I. 


Theorem 3.18. Let G be the derived graph of A. If A is almost perfect and 
does not contain the n x n submatrix J — IJ, then 


G) n= a(G)a(G) + 1; 
(ii) every vertex of G is in exactly w cliques of size w and in exactly « stable 
sets of size «; 
iii) G has exactly n maximum cliques and n maximum stable sets; 
(iv) there is a numbering of the maximum cliques K,, K,,..., K, and 
maximum stable sets S,,5,,..., 8, of G such that K; 0 S; = @ ifand only if 


i=j. 
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Figure 3.4. The derived graph G of the matrix A isa perfect graph, yet P(A) has (4, 4,4,0,0, 0) 
as an extremum; thus A is an imperfect matrix. A’ is the clique matrix of G and is perfect. 


Theorem 3.19. A is perfect if and only if A is an augmented clique matrix 
of its derived graph and the derived graph is perfect. 


Corollary 3.20. A is almost perfect if and only if either (i) A is an aug- 
mented clique matrix of its derived graph and the derived graph is almost 
perfect (p-critical) or (ii) A has no row of all ones and contains the n x n 
submatrix J — Iforn > 3. Furthermore, in (ii) the derived graph is complete. 


Corollary 3.21. Every p-critical graph has the four properties of Theorem 
3.18. 


Note carefully the wording of Theorem 3.19. It is very possible that A is 
not a perfect matrix and yet its derived graph G is perfect and every row of A 
corresponds to a maximal clique of G. Of course, in this case, by Theorem 
3.19, the matrix is missing a row corresponding to some other maximal 
clique (see Figure 3.4). 

Theorems 3.16, 3.17, 3.19, and Corollary 3.20 are very useful when con- 
sidering graphs as incidence matrices. Corollary 3.21 is a restatement of 
Corollary 3.12. 

To show Theorems 3.16 and 3.17 we will turn to the concept of anti- 
blocking polyhedra (Fulkerson [1971, 1972]). Two polyhedra P, and P, 
are an antiblocking pair if P, = {x|xP, < 1, x > 0} or P, = {ylyP, < 1, 
y > 0}, the conditions being equivalent. If P, is generated from a (0, 1)- 
valued matrix A, having no zero column, then we have the property, among 
many others, that every extremum of P, is a projection of some row of A, 
and every nonredundant row of A, is an extremem of P, (Fulkerson [1972]). 
The same result holds if we interchange the indices. 

Let b™, b®, ..., b™ be the extrema of P,; and denote the matrix having 
rows b™, b™,..., b® by B. Define Q = P(B),Q, = P,(B) and Q; = P,(B) for 
j =1,2,...,n. The polyhedra P, and Q are an antiblocking pair (Fulkerson 
[1972]). By Lemma 3.13, the rows of B correspond to all of the stable sets 
of G, the derived graph of A. Thus, B is an augmented clique matrix of the 
complement G. See also Monma and Trotter [1979]. 
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Proof of Theorem 3.16. Let A be perfect (P; = P) and G be its derived 
graph. Since P, and Q are an antiblocking pair, P and Q are also an anti- 
blocking pair. By the properties of antiblocking pairs, the extrema of Q must 
all be projections of the rows of A, so Q is integral. By Lemma 3.13, all the 
stable sets of G, in other words all the cliques of G, are extrema of Q, since 
Q = Q,. Thus, every clique of G must be a projection of some row of A. 
Therefore, A is an augmented clique matrix of its derived graph. | 


Proof of Theorem 3.17. Assuming that A is almost perfect, P; is integral 
for j = 1, 2,..., n. By a similar argument to that for Theorem 3.16, each Q; 
is also integral. This follows since P(A) 7 {x € R"|x; = 0} is the same as 
removing the jth column from A and forming its polyhedron. 


Case 1: Q is not integral and thus is almost integral. In this case Padberg 
was able to show by a direct analysis of the facets of P that P and Q, are an 
antiblocking pair. As in the proof of Theorem 3.16, we have that A is an 
augmented clique matrix of its derived graph. 


Case 2: Q is integral. In this case Padberg was able to show by the non- 
integrality of P that 1 is an extremum of Q. This means that B must be the 
identity matrix (or a permutation of it). This in turn implies that the derived 
graph of A is complete. Therefore, for P; to be integral, some row k of the 
matrix formed by deleting the jth column of A must be all ones (Theorem 
3.16). Yet no row in A can have all ones since A is only almost perfect. Thus, 
row k in A must be all ones except for a zero in column j. Since this is true for 
all j = 1, 2,...,n, A contains the n x n submatrix J — I. | 


Although Theorem 3.18 is essentially contained among the results of 
Section 3.3, Padberg’s proof does not use the Perfect Graph theorem and his 
technique is valuable in its own right. Before proving Theorem 3.18 we state 
Padberg’s cornerstone lemma. 


Lemma 3.22. If x is a nonintegral extremum of an almost integral 
polyhedron P, then for every n x n nonsingular submatrix A, of A such 
that A,x = 1, there exists ann x n nonsingular submatrix B, of B satisfying 
the matrix equation 


B,Al = J =, L 
Furthermore, 
x = (1/((n — 1))Bf1. 


As a quick observation, we note that for any noninteger extremum x of P, 
x > 0. If for some k, x, = 0, then x € P, and thus is an extremum of P,. But 
then x would have to be integral. The only way x could be an extremum of P 
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is to satisfy n linearly independent constraints of Ax < 1. Let A, be then x n 
nonsingular submatrix of A. Thus, for each x there does exist such an A, as 
specified in Lemma 3.22. 

Padberg was also able to show that x, a noninteger extremum of P, is the 
unique noninteger extremum; that y = (1/(n — 1))A1I, for any A, of Lemma 
3.22, is an extremum of Q; and that for any A, and corresponding B, of 
Lemma 3.22, x = |det Ay '|1 and y = |det By '|1. Armed with these matrix 
equations, the proof of Theorem 3.18 is a straightforward exercise in linear 
algebra. 


Proof of Theorem 3.18. Let G be the derived graph of A, where A is almost 
perfect and does not contain the n x n submatrix J — I. By the definition of 
almost perfect we have the existence of a noninteger extremum x of P. By 
Lemma 3.22 and the previous discussion, x is unique and there exist n x n 
nonsingular submatrices A, of A and B, of B such that A,x = 1 and B, Af 
= J — I. Moreover, for allsuch A, and B,,x = (1/(n — 1))BT1 = |det A; *{1, 
and y, defined by y = (1/(n — 1))AT1 = [det By '|/1, is an extremum of Q. 

We shall first show that A, is unique, in that any row a, of A satisfying 
a,‘ xX = 1 is in A,. We have the following implications: 


B,Al = J -I>A,BT=J—I1=>BT =X — Aj'= Aj! =X - BY, 


where X is the n x n matrix having n columns of x. Thus, if a, *x = 1, then 
a,A;' =a,X —a,B! is 0 or 1, yet a,A;':1=a,'x =1. Therefore, 
a,A;’ = e,, the jth unit vector, for some je {1, 2,...,n}. This implies that a, 
is equal to the jth row of A,, that is, a, is in A,. Finally, since x = |det Aj '/1, 
we have that A, contains exactly all the rows of A having the maximum 
number of ones. By Theorem 3.17, A is an augmented clique matrix of G. 
Therefore, A, must contain exactly all the maximum cliques of G. 
A similar argument holds for y, B,, B and G. Since 


By = B,((1An — 1))ATD = 1, 
we have B,; 1 = Y — Al. Thus for any row b, of B satisfying b,:y = 1, we 
have b, By’ = b, Y — b, AT, and yet b, By 1-1 =b,-y = 1. So b, is in B,. 
Since y = |det Bj +|1, and since by construction B is an augmented clique 


matrix of G, we have that B, must contain exactly all the maximum cliques 
of G. 
(i) The row sum of A, is w(G), yet A,1 = A,[det A, |x = {det A,[1; 
thus |det A,| = w(G). Similarly for B,, the row sum is a(G), yet 
B,1 = B, |det B,|y = |det B,|1; 


so |det B,| = «(G). Therefore, o(G)w(G) = |det B,AT| = |det (E — D| = 
\(—1)""1(n — 1)| = n — 1. Thus, n = «(G)o(G) + 1. 
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Gi) Since y = (1/(n — 1))ATI, we have (1/x)1 = (1/em), AT1, and thus 
1 = ATI. That is, all the column sums of A, are w. Therefore, every vertex is 
in exactly w cliques of size w. 

Similarly for x, x = (1/(n — 1))B11 implies (1/w)1 = (1/aw)BT1, and 
hence «1 = BI1. Therefore, every vertex is in exactly « stable sets of size «. 

(iii) A, is ann x n nonsingular matrix containing exactly all the maxi- 
mum cliques of G; therefore, G has exactly n maximum cliques. By a similar 
argument on B,, G has exactly n maximum stable sets. 

(iv) Let K; correspond to the ith row of A, for i = 1, 2,..., n, and S; 
correspond to the jth row of B, for j = 1, 2,...,n. Since B,A] = J — I, the 
maximum cliques K,, K,,..., K, and maximum stable sets S,, S,,..., S, 
of G are numbered such that K; 7 S; = @ if and only if i = j. I 


The “only if” condition of Theorem 3.19 is a stronger statement than 
Theorem 3.16; it states that the derived graph itself is perfect, which also 
turns out to be a sufficient condition for A to be perfect. In fact, Theorem 3.19 
is precisely Chvatal’s Theorems 3.14 and 3.16 put together. A more direct 
proof here will be instructive. Again we need an intermediate result of 
Padberg’s. 


Lemma 3.23. P is integral if and only if max,.,;.<p q° x =0 mod 1 for 
all (0, 1)-valued q. 


It is well known that for a general matrix A with non-negative entries and 
no zero column, satisfying max,,,;,<p ¢*X = 0 mod 1 for all non-negative c 
is equivalent to P being integral. But for our matrix A, considering only 
(0, 1)-valued q is sufficient. 


Proof of Theorem 3.19. (<=) Let A be an augmented clique matrix of its 
derived graph G, where G is perfect. Let q be a (0, 1)-valued vector and G’ its 
corresponding induced subgraph of G. Then 


a(G')= max q°x < max q:x= min yl 
subjxe Py; subj xeP subj yA>q, y20 
< min y°1=k(G). 


subj yA>q, y>9, integral 


The first equality is clear because of Lemma 3.13 and the fact that an optimal 
solution can always be found at an extremum. The last equality is true since 
A is an augmented clique matrix and any optimal y is (0, 1)-valued. The in- 
equalities have been seen before in Section 3.4. 

Now since G is perfect, we must have equality everywhere. Thus, 


max q-x =0Omod1. 
subj xeP 
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Finally, since q was arbitrary, Lemma 3.23 implies that P is integral, and thus 
A is perfect. 

(=) Let A be perfect. By Theorem 3.16, A is an augmented clique 
matrix of its derived graph. To show that G is perfect we shall use induction 
on the size of the induced subgraphs. 

For |G'| = 0 it is clear that a(G’) = k(G’). Assume that every k-vertex 
induced subgraph is perfect. Given |G'| = k + 1, let q be the characteristic 
vector of G’. Since P is integral and A is an augmented clique matrix of G, 


a(G’) = max q'x= min yel< min y-l 
subj xeP subj yA>q, y>0 subj yA>q, y= 9, integral 
= k(G’). (10) 


We claim that there is an integer optimal solution for min,.4; ya>q, yoo Y* I. 
We know that an optimal solution y exists. If y is integral we are done; 
otherwise there is a k such that 0 < y, < 1. Clearly the kth row a, of A has 
the property a,°q > 0, for otherwise y would not be optimal. Define g; = q; 
for a,; = 0 and g; = 0 for a,; = 1. Since q is the characteristic vector of a 
smaller induced subgraph, and since (10) still holds, there is an integer 
optimal solution y for q. Clearly any optimal solution for g has its kth 
component zero; thus y is feasible but not optimal for q. Yet y*, where y* = ¥ 
except for y* = 1, is feasible for q. That is, 
min yil< min y°l<y*-l= min yrl+t. 
subj yA>q, y>0 subj yA>q, y>0 subj yA>q, y20 

Therefore, y* is an integer optimal solution for min,y4;ya>q, y20 Y* 1 and 
thus «(G’) = k(G’). | 


The observant reader will notice that the same “only if” proof could have 
been used in Theorem 3.14. 
The proofs of Corollaries 3.20 and 3.21 are now easy. 


Proof of Corollary 3.20. (<=) Case 1: Let A be an augmented clique 
matrix of its derived graph G, where G is p-critical. Since deleting any vertex 
j of G results in a perfect graph, all the P; are integral. Yet by Theorem 3.19, 
A is imperfect because G is imperfect; therefore A is almost perfect. 


Case 2: Let A have no row of all ones and contain the n x n submatrix 
J — I for n > 3. Since each P; is obtained from the matrix A with its jth 
column deleted, and since this submatrix has a row containing all ones, all 
P; are integral. Yet (1/(n — 1))! is an extremum of P, since every row has at 
most n — 1 ones and J — I is an n x n submatrix. Therefore A is almost 
perfect. 

(=) Given that A is almost perfect, we apply Theorem 3.17 to obtain 
two cases. 
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Case 1: A is an augmented clique matrix of its derived graph G. By Theorem 
3.19 each P; is integral, the submatrix of A obtained by deleting the jth column 
is perfect, and thus the deletion of any vertex j of G results in a perfect graph. 
Yet by Theorem 3.19 again, G itself is not perfect since A is not perfect. 
Therefore, G is p-critical. 


Case 2: A contains the n x n submatrix J — 1. Clearly A does not contain 
a row ofall ones, for otherwise A would be perfect. Finally, we must certainly 
have n > 3, thus G is complete. | 


: Proof of Corollary 3.21, Given a p-critical graph G, form A, its clique 
matrix. By Corollary 3.20, case 1, A is almost perfect. Certainly G is the de- 
rived graph of A, and thus the hypothesis of Theorem 3.18 is satisfied. I 


6. The Strong Perfect Graph Conjecture 


The odd cycle C,,,, (for k > 2) is not a perfect graph since «(Cz,,,) =k 
and k(C,41) = k + 1 (or, alternatively, since w(C2,4,) = 2 and 7(C2,+4) 
= 3). However, every proper subgraph of C2,,, is perfect. Thus, C.,4, isa 
p-critical graph (i.e., minimally imperfect) and by the Perfect Graph theorem 
its complement C3,,; is also p-critical. To date, these are the only known p- 
critical graphs. 

During the second international meeting on graph theory, held at Halle-on- 
Saal in March 1960, Claude Berge raised the question of whether or not other 
p-critical graphs besides the odd cycles and their complements exist. He 
conjectured that there are none, and this has come to be known as the 
strong perfect graph conjecture (SPGC). (Actually, the word “conjecture” 
first appeared in Berge [1962].) 

The strong perfect graph conjecture may be stated in several equivalent 
forms: 


SPGC,. An undirected graph is perfect if and only if it contains no in- 
duced subgraph isomorphic to C.,,1 or C2, (for k > 2). 

SPGC,. An undirected graph G is perfect if and only if in G and in G 
every odd cycle of length >5 has a chord. 

SPGC,. The only p-critical graphs that exist are C,,,, and Cy,4, 
(for k > 2). 


The graphs C,,,, and C,,,, are commonly referred to as the odd hole 
and the odd antihole, respectively. 

We have seen in Sections 3.3 and 3.5 that p-critical graphs reflect an extra- 
ordinary amount of symmetry (as indeed they should if the SPGC turns out 
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to be true). Let G be a p-critical graph on n vertices, and let « = a(G) and 
@ = @(G). Then the following conditions hold for G. 


Lovasz condition 
n=¢6w0 +1 


Padberg conditions 

Every vertex is in exactly @ maximum cliques (of size @). 

Every vertex is in exactly « maximum stable sets (of size ). 

G has exactly n maximum cliques (of size w). 

G has exactly n maximum stable sets (of size «). 

The maximum cliques and maximum stable sets can be indexed K,, 
K,,..., K, and S,, $2, ..., S,, respectively, so that |K; 1 S;| = 1 — 6 
where 6,; is the Kronecker delta. 


ij? 


Clearly, any p-critical graph must be connected. But C, is the only con- 
nected graph on n vertices for which @ = 2 and having exactly n undirected 
edges such that each vertex is an endpoint of exactly two of these edges. So, 
by Padberg’s conditions we obtain another equivalent form of the strong 
perfect graph conjecture: 


SPGC,. There is no p-critical graph with a > 2 and w > 2. 


Recall from Section 3.3 that a partitionable graph on n vertices satisfies 
the Lovasz and Padberg conditions. 

Figures 3.5 and 3.9 give two examples of (3, 3)-partitionable graphs which 
fail to be p-critical. For this reason, the Lovasz and Padberg conditions alone 
are not sufficient to prove the SPGC. Nevertheless, partitionable graphs do 
give us further reductions of the SPGC. 

One special type of partitionable graph is easy to describe. The undirected 
graph C¥ has vertices v,, v.,v3,..., ¥, With v; and v; joined by an edge if and 
only if i and j differ by at most d. (Here and in the next theorem all subscript 
arithmetic is taken modulo n.) It is easy to see that the graph C2), is an 
(a, w)-partitionable graph. When w = 2, then C®;,), is simply the odd hole 
C2241; when « = 2, then C2, is the odd antihole C,,,,,- 


-Theorem 3.24 (Chvatal [1976]). For any integers « > 3 and w > 3, the 
partitionable graph C®;,!, is not p-critical. 


Proof. Let «a > 3 and w > 3 be given. We will show that C2,,!, contains 
a proper induced subgraph H which is not perfect. 

If we index the n = aw — 1 maximal cliques {K;} of C®;,!, so that K; = 
{0;, Ui445-+-» Uj+@—1} for each 1 < i < n, then the clique matrix of the graph 
has the familiar cyclical pattern, as shown in Figure 3.6. Let H denote the 
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o12345 67 89 o12345 678 9 
K 5 
hy 2 
% Ss 
K S 
Ks Ss 
Ke Se 
KK Sy 
LA Se 
Ky 5, 
Ke Seo 
Clique matrix Stable set matrix 


Figure 3.5. A graph satisfying the Lovasz and Padberg conditions which fails to be p-critical. 
The clique matrix and stable set matrix indicate the required indexing of the maximum cliques 
and maximum stable sets. This example was discovered independently by Huang [1976] and by 
Chvatal, Graham, Perold, and Whitesides [1979]. 


subgraph remaining after deleting the « + 2 vertices v,, 02, 0441, Vo+3, and 
all v,,42 for t = 2, 3, ..., « — 1. In the deleting process every maximum 
clique has lost at least one of its members, so w(H) < w — 1. Therefore, it 
suffices to show that H cannot be colored using w — 1 colors. 


Suppose that H is w — 1 colorable. Let v, be colored black and let the 
@ ~ 2 additional colors be called the rainbow. We have the following series 
of implications: 


{v1, 03,-+-, Uo} < K, => {v3,..., 0} requires the entire rainbow; 
{053,.--5 Va. Vq+2} & Kz => 0442 Is black; 


{0542 Vat4s+++> Prati} © Kase 
=> {U,44)-++> 2941} requires the entire rainbow; 


{Vq449+++5 V20+ 19 P2043} © Kat4 > Y2@+3 IS black; 
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_—— oe 


Figure 3.6. The clique matrix of C2,’,, where w = 4and « = 5. The markers designate which 


ao 


vertices are to be deleted to obtain an imperfect subgraph. 


and finally, by induction on t, 
Vieg + 3 IS black 


=> {Viy44s-++s Yet tyo+1} Tequires the entire rainbow 
=> {044 1)0+3} is black, 


fort = 2,...,«0 —2. 


Therefore, both v, and v,,_ 1).+3 are black, but they are both contained in the 
clique Kiq- 1)+3, @ contradiction. Hence, y(H) > @ — 1 > w(H) and H is 
imperfect as required. 


As acorollary of Theorem 3.24 we obtain another equivalent version of the 
strong perfect graph conjecture: 


SPGC,. If Gis p-critical with «(G) = « and w(G) = a, then G contains 
an induced subgraph isomorphic to C2>,,. 


Chvatal, Graham, Perold, and Whitesides [1979] have presented two 
procedures for constructing (a, «)-partitionable graphs other than C2;,};. 

If we we restrict the universe of graphs being considered by making an 
extra assumption about their structure, then, in certain cases, the SPGC can 
be shown to hold. Table 3.1 lists some successful restrictions. For the most 
part the original proofs cited do not make use of the Padberg conditions. 
Tucker [1979] has incorporated the Padberg conditions into new proofs of 
the SPGC for K,, 3-free graphs and 3-chromatic graphs. 
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Table 3.1 


Classes of graphs for which the strong perfect graph conjecture 
is known to hold 


Planar graphs Tucker [{1973a] 

K, 3-free graphs Parthasarathy and Ravindra [1976} 
Circular-arc graphs Tucker {1975] 

N-free graphs Parthasarathy and Ravindra [1979] 


3-chromatic graphs 

(actually, any graph with w < 3) Tucker [1977] 
Toroidal graphs; graphs having 

maximum vertex degree < 6 Grinstead [1978] 


The strong perfect graph conjecture remains a formidable challenge to us. 
Its solution has eluded researchers for two decades. Perhaps in the third 
decade a reader of this book will settle the problem. 


EXERCISES 


1. Let x and y be distinct vertices of a graph G. Prove that (Go x) — y= 
(G — y)ox. 
2. Let x,, x2,..., X, be the vertices of a graph G and let H = Goh where 
h = (hy, h,,..., h,) is a vector of non-negative integers. 
Verify that H can be constructed by the following procedure: 
begin 
H<-G; 
for i — 1 tondo 
ifh; = 0 then H — H — x;; 
else while h; > 0 do 
begin 
He Hex;; 
h,~ h, — 1; 
end 
end 


3. Give an example of a graph G for which a(G) = k(G) and a(G) < x(G). 
Why does tiis not contradict the Perfect Graph theorem? 

4. Suppose G satisfies «(G) = k(G). Let ¥ be a clique cover of G where 
| #°| = k(G), and let S be the collection of all stable sets of cardinality «(G). 
Show that 


ISQK|=1 for all Se FY and Ke #. 
Give a dual statement for a graph satisfying w(G) = y(G). 
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5. Prove the following: For any integer k, there exists a graph G such that 
o(G) = 2 and x(G) = k. Thus, the gap between the clique number and the 
chromatic number can be arbitrarily large (Tutte [1954], Kelly and Kelly 
[1954], Zykov [1952]; see also Sachs [1969)). 

6. Prove that an n-vertex graph G is an odd chordless cycle if and only if 
n= 2k + 1, o(G) =k, and a(G — v — w) = k for all vertices v and w of G 
(Melnikov and Vising [1971], Greenwell [1978]). 

7. An undirected graph G is unimodular if its clique matrix A has the prop- 
erty that every square submatrix of A has determinant equal to 0, +1, or 
— 1. Prove the following: 


(i) The graph in Figure 3.7 is unimodular; 
(li) unimodularity is a hereditary property; 
(iii) a bipartite graph is unimodular; 
(iv) aunimodular graph is perfect (if necessary, for (iv) see Berge [1975]). 


WWAVAV A 


Figure 3.7 


8. Show that the five versions of the strong perfect graph conjecture given in 
this chapter are equivalent. 

9. Prove that G is p-critical if and only if G is partitionable but no proper 
induced subgraph of G is partitionable. 

10. Show that the graph in Figure 3.8 is partitionable but not p-critical. 
Show that the graph in Figure 3.9 is imperfect but not partitionable. 


Figure 3.8 
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Figure 3.9 


11. Let A and B be n x n matrices and let « and @ be integers. Using 
matrix operations give a short proof of the following: If AJ = JA = oJ, 
BJ = JB = aJ, and AB’ = J — I, thenaw =n — 1. 

12. Let G = (X, E) and H = (Y, F) be undirected graphs. Their normal 
product is defined to be the graph G- H whose vertex set is the Cartesian 
product X x Y with vertices (x, y) and (x’, y’) adjacent if and only if 


x=x’ and yy'eF or xx’eE and y=y 
or 
xx'eE and yy'eF. 
Prove the following: 


(i) x(G-h) = max{x(G), x(A)}; 
(ii) @(G-H) = o(G)o(A); 
(ili) o(G- H) => a(G)a(A); 
(iv) k(G-H) < k(G)kK(A). 
13. Let G" denote the normal product of G with itself r — 1 times, i.e., 
G' = Gand G’ = G-G""!. Let 


c(G) = sup ./a(G’). 


Prove that «(G) = k(G) implies c(G) = a(G). For an application of this to 
zero-capacity codes, see Berge [1973, p. 382; 1975, p. 13]. 
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CHAPTER 4 


Triangulated Graphs 


1. Introduction 


One of the first classes of graphs to be recognized as being perfect was the 
class of triangulated graphs. Hajnal and Suranyi [1958] showed that tri- 
angulated graphs satisfy the perfect property P, (a-perfection), and Berge 
[1960] proved that they satisfy P, (y-perfection). These two results, in large 
measure, inspired the conjecture that P, and P, were equivalent, a statement 
that we now know to be true (Theorem 3.3). Thus, the study of triangulated 
graphs can well be thought of as the beginning of the theory of perfect graphs. 

We briefly looked at the triangulated graph property in the sneak preview 
Section 1.3. For completeness’ sake, we shall repeat the definition here and 
mention a few basic properties. 

An undirected graph G is called triangulated if every cycle of length strictly 
greater than 3 possesses a chord, that is, an edge joining two nonconsecutive 
vertices of the cycle. Equivalently, G does not contain an induced subgraph 
isomorphic to C, for n > 3. Being triangulated is a hereditary property 
inherited by all the induced subgraphs of G. You may recall from Section 1.3 
that the interval graphs constitute a special type of triangulated graph. Thus 
we have our first example of triangulated graphs. 

In the literature, triangulated graphs have also been called chordal, rigid- 
circuit, monotone transitive, and perfect elimination graphs. 


2. Characterizing Triangulated Graphs 


A vertex x of G is called simplicial if its adjacency set Adj(x) induces a 
complete subgraph of G, 1e., Adj(x) is a clique (not necessarily maximal). 
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Dirac [1961], and later Lekkerkerker and Boland [1962], proved that a 
triangulated graph always has a simplicial vertex (in fact at least two of them), 
and using this fact Fulkerson and Gross [1965] suggested an iterative pro- 
cedure to recognize triangulated graphs based on this and the hereditary 
property. Namely, repeatedly locate a simplicial vertex and eliminate it from 
the graph, until either no vertices remain and the graph is triangulated or at 
some stage no simplicial vertex exists and the graph is not triangulated. The 
correctness of this procedure is proved in Theorem 4.1. Let us state things 
more algebraically. 

Let G = (V, E) be an undirected graph and let o = [v,, v2,..., v,] be an 
ordering of the vertices. We say that o is a perfect vertex elimination scheme 
(or perfect scheme) if each v; is a simplicial vertex of the induced subgraph 
»,)- 1n other words, each set 


X; = {v;e Adj(v)|j > i} 


is complete. For example, the graph G, in Figure 4.1 has a perfect vertex 
elimination scheme o = [a, g, b, f, c, e, d]. It is not unique; in fact G, has 96 
different perfect elimination schemes. In contrast to this, the graph G, has 
no simplicial vertex, so we cannot even start constructing a perfect scheme— 
it has none. 

A subset S c V is a vertex separator for nonadjacent vertices a and b (or 
an a-b separator) if the removal of S from the graph separates a and b into 
distinct connected components. If no proper subset of S is an a—b separator, 
then S is a minimal vertex separator for a and b. Consider again the graphs of 
Figure 4.1. In G,, the set {y, z} is a minimal vertex separator for p and q, 
whereas {x, y, z} is a minimal vertex separator for p and r. (How is it possible 
that both are minimal vertex separators, yet one is contained in the other?) 
In G,, every minimal vertex separator has cardinality 2. This is an unusual 
phenomenon. However, notice also that the two vertices of such a separator 
of G, are adjacent, in every case. This latter phenomenon actually occurs for 
all triangulated graphs, as you will see in Theorem 4.1. 
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Figure 4.1. Two graphs, one triangulated and one not triangulated. 
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We now give two characterizations of triangulated graphs, one algorithmic 
(Fulkerson and Gross [1965]) and the other graph theoretic (Dirac [1961)). 


Theorem 4.1. Let G be an undirected graph. The following statements are 
equivalent: 


(i) G is triangulated. 
(ii) G has a perfect vertex elimination scheme. Moreover, any simplicial 
vertex can start a perfect scheme. 
(iii) Every minimal vertex separator induces a complete subgraph of G. 


Proof. (iii) => Gi) Let [a, x, b, yy, y2,---, Ye, @] (kK = 1) be a simple cycle 
of G = (V, E). Any minimal a-b separator must contain vertices x and y; for 
some i, So xy; € E, which is a chord of the cycle. 

(i) > (iit) Suppose S is a minimal a—b separator with G, and Gp, being the 
connected components of G,_; containing a and b, respectively. Since S is 
minimal, each x eS is adjacent to some vertex in A and some vertex in B. 
Therefore, for any pair x, ye S there exist paths [x, a,,..., a,, y] and [y, 
b,,..., b,, x], where each a; € A and b; € B, such that these paths are chosen 
to be of smallest possible length. It follows that [x, a,,...,4,, ¥,b1,...,5,,x] 
is a simple cycle whose length is at least 4, implying that it must have a chord. 
But a;b;¢ E by the definition of vertex separator, and a,a;¢ E and b,b;¢ E 
by the minimality of r and t. Thus, the only possible chord is xy € E. | 


Remark. It also follows that r = t = 1, implying that for all x, ye S there 
exist vertices in A and B which are adjacent to both x and y. A stronger result 
is given in Exercise 12. 


Before continuing with the remaining implications, we pause for a message 
from our lemma department. 


Lemma 4,2 (Dirac [1961]). Every triangulated graph G = (V, E) has a 
simplicial vertex. Moreover, if G is not a clique, then it has two nonadjacent 
simplicial vertices. 


Proof. The lemma is trivial if G is complete. Assume that G has two non- 
adjacent vertices a and b and that the lemma is true for all graphs with fewer 
vertices than G. Let S be a minimal vertex separator for a and b with G, and 
G, being the connected components of G, _s containing a and b, respectively. 

By induction, either the subgraph G,,, has two nonadjacent simplicial 
vertices one of which must be in A (since S induces a complete subgraph) or 
G445is itself complete and any vertex of A is simplicialin G, , 5. Furthermore, 
since Adj(A) € A + S, a simplicial vertex of G,,, in A is simplicial in all of 
G. Similarly B contains a simplicial vertex of G. This proves the lemma. 
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We now rejoin the proof of the theorem which is still in progress. 


(i) = Gi) According to the lemma, if G is triangulated, then it has a 
simplicial vertex, say x. Since Gy _,,, is triangulated and smaller than G, it 
has, by induction, a perfect scheme which, when adjoined as a suffix of x, 
forms a perfect scheme for G. 

(ii) > (i) Let C be a simple cycle of G and let x be the vertex of C with 
the smallest index in a perfect scheme. Since | Adj(x) m C| > 2, the eventual 
simpliciality of x guarantees a chord in C. | 


3. Recognizing Triangulated Graphs by Lexicographic 
Breadth-First Search 


From Lemma 4.2 we learned that the Fulkerson-Gross recognition 
procedure affords us a choice of at least two vertices for each position in 
constructing a perfect scheme for a triangulated graph. Therefore, we can 
freely choose a vertex v, to avoid during the whole process, saving it for the 
last position in a scheme. Similarly, we can pick any vertex v,_, adjacent to 
v, to save for the (n — 1)st position. If we continued in this manner, we would 
be constructing a scheme backwards! This is exactly what Leuker [1974] and 
Rose and Tarjan [1975] have done in order to give a linear-time algorithm 
for recognizing triangulated graphs. The version presented in Rose, Tarjan, 
and Leuker [1976] uses a lexicographic breadth-first search in which the 
usual queue of vertices is replaced by a queue of (unordered) subsets of the 
vertices which is sometimes refined but never reordered. The method 
(Figure 4.2) is as follows: 


begin 
assign the label @ to each vertex; 
for i — nto 1 step — 1 do 
select: pick an unnumbered vertex v with largest label: 
o({i) — v; comment This assigns to v the number /. 
update: for each unnumbered vertex we Adj(v) do add i to label(w); 
end 


Ae eal aad ca 


Figure 4.2. Algorithm 4.1: Lex BFS. 
Algorithm 4.1. Lexicographic breadth-first search. 


Input: The adjacency sets of an undirected graph G = (V, E). 

Output: An ordering o of the vertices. 

Method: The vertices are numbered from n to | in the order that they are 
selected in line 3. This numbering fixes the positions of an elimination scheme 


3. Recognizing Triangulated Graphs 85 


c 


Figure 4.3. 


o. For each vertex x, the label of x will consist of a set of numbers listed in 
decreasing order. The vertices can then be lexicographically ordered accord- 
ing to their labels. (Lexicographic order is just dictionary order, so that 
9761 < 985 and 643 < 6432.) Ties are broken arbitrarily. 


Example. We shall apply Algorithm 4.1 to the graph in Figure 4.3. The 
vertex a is selected arbitrarily in line 3 during the first pass. The evolution of 
the labeling and the numbering are illustrated in Figure 4.4. Notice that the 
final numbering o = [c, d, e, b, a] is a perfect vertex elimination scheme. This 
is no accident. 

For each value of i, let L{x) denote the label of x when statement 4 is 
executed, i.e., when the ith vertex is numbered. Remember, the index is 
decremented at each successive iteration. For example, L,(x) = @ for all x 
and L,_ (x) = {n} iff x e Adj(o(n)). The following properties are of prime 
importance: 


(LILA) < L(x) = si); 

(L2) L(x) < Lily) > L{x)<Lfy) GU <); 

(L3) if o '(a) <a ‘(b) <a '(c) and ce Adj(a) — Adj(b), then there 
exists a vertex d € Adj(b) — Adj(a) with a7 '(c) < a7 '(d). 


label number fabel number label number label number 


¢ 


¢ 
¢ 
¢ 
$ 


Figure 4.4. 
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Property (L1) says that the label ofa vertex may get larger but never smaller 
as the algorithm proceeds. Property (L2) states that once a vertex gets ahead 
of another vertex, they stay in that order. Finally, (L3) gives a condition under 
which there must be a suitable vertex d which was numbered before c (in 
time) and hence received a larger number. 

Lexicographic breadth-first search can be used to recognize triangulated 
graphs as demonstrated by the next theorem. : 


Theorem 4.3. An undirected graph G = (V, E) is triangulated if and only 
if the ordering o produced by Algorithm 4.1 is a perfect vertex elimination 
scheme. 


Proof. If|V| =n = 1, then the proof is trivial. Assume that the theorem 
is true for all graphs with fewer than n vertices and let o be the ordering pro- 
duced by Algorithm 4.1 when applied to a triangulated graph G. By induction, 
it is sufficient to show that x = a(1) is a simplicial vertex of G. 

Suppose x is not simplicial. Choose vertices x,, x. € Adj(x) with x,x,¢@E 
so that x, is as large as possible (with respect to the ordering a). (Remember, 
o increases as you approach the root of the search tree.) Consider the follow- 
ing inductive procedure. Assume we are given vertices x,, X2,..., Xj, With 
these properties: for all i, j > 0, 


(1) x,x,eEei< 2, 

(2) x;x;eE|i —j| = 2, 

(3) a *(x,) < a "(x2) < +++ < a "(xq), 

(4) x; is the largest vertex (with respect to a) such that 


Xj-2X;EE but xj-3xj,€E. 


(For notational reasons let x») = x and x_,; = x,.) The situation for m = 2 
was constructed initially. 

The vertices x,,-2; Xm—1, and x,, satisfy the hypothesis of property (L3) 
as a, b, and c, respectively. Hence, choose x,,, to be the largest vertex (with 
respect to o) larger than x,, which is adjacent to x,,_, but not adjacent to 
Xm-2- Now, if x,,4, were adjacent to x,,_ 3, then (L3) applied to the vertices 
Xm—3> Xm—2> Xm+1 Would imply the existence of a vertex larger than x,,4; 
(hence larger than x,,) which is adjacent to x,,_, but not to x,,_3, con- 
tradicting the maximality of x,, in (4). Therefore x,,,, is not adjacent to 
Xm—3+ Finally, it follows from (1), (2), and chordality that x;x,,,,¢E for 
i=0,1,...,m—4,m. 

Clearly this inductive procedure continues indefinitely, but the graph is 
finite, a contradiction. Therefore, the vertex x must be simplicial, and the 
theorem is proved in one direction. The converse follows from Theorem 4.1. 
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In an unpublished work, Tarjan [1976] has shown another method of 
searching a graph that can be used to recognize triangulated graphs. It is 
called maximum cardinality search (MCS), and it is defined as follows: 


MCS: The vertices are to be numbered from n to 1. 
The next vertex to be numbered is always one which is adjacent to the most 
numbered vertices, ties being broken arbitrarily. 


Using an argument similar to the proof of Theorem 4.3, one can show that G 
is triangulated if and only if every MCS ordering of the vertices is a perfect 
ellimination scheme. It should be pointed out that there are MCS orderings 
which cannot be obtained by Lex BFS, there are Lex BFS orderings which are 
not MCS, and there exist perfect elimination schemes which are neither 
MCS nor Lex BFS. Exercises 27 and 28 develop some of the results on MCS. 
Both Lex BFS and MCS are special cases of a general method for finding 
perfect elimination schemes recently developed by Alan Hoffman and 
Michel Sakarovich. 


4. The Complexity of Recognizing Triangulated Graphs 


Having proved the correctness of Algorithm 4.1, let us now analyze its 
complexity. We first describe an implementation of Lex BFS, then show that 
it requires O(|V| + |E|) time. We do not actually calculate the labels, but 
rather we keep the unnumbered vertices in lexicographic order. 


Data Structure 


We use a queue Q of sets 
S, = {ve V|label(v) = land ao” 1(v) undefined} 


ordered lexicographically from smallest to largest; each set S, is represented 
by a doubly linked list. Initially there is but one set, S, = V. Each set S, has 
a FLAG initially set at 0. For a vertex w, the array element SET(w) points to 
Stabe) 4d another array gives the address of w in SET(w) for deletion 
purposes. A list FIX LIST, initially empty, is also used, and simple arrays 


represent o anda". 


Implementation 


Select as v in line 3 any vertex in the last set of Q and delete v from SET(v). 
Create a new set S,.; for each old set S, containing an unnumbered vertex 
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w € Adj(v). We delete from S, all such vertices w and place them in the new 
set S,.;, which is inserted into the queue of sets immediately following S,. 
Clearly this method maintains the proper lexicographic ordering without our 
actually having to calculate the labels. More specifically, update can be 
implemented as follows: 


for all unnumbered ' € Adj(v) do 
begin 
if FLAG(SET()) = 0 then 
begin 
Create new set S’ and insert it in Q immediately in back of SET(w); 
FLAG(SET(w)) — 1; FLAG(S’) < 0; put a pointer to SET (w) on FIX LIST; 
end 
let S’ be the set immediately in back of SET(w) in Q; delete w from SET(w); add wto S’; 
SET(w) < S’; 
end 
for each set S on FIX LIST do 
begin 
FLAG(S) < 0; 
if S is empty then 
delete S from Q; 
end 


It is easy to verify that, as presented, statement 5 requires O(|Adj(v)|) 
time. Consequently, the for loop between statements 2 and 5 uses O({V| + 
| £|) time. Initializing the data structure including statement 1 takes O(|V |) 
time. This proves the following result. 


Theorem 4.4. Algorithm 4.1 can be implemented to carry out lexico- 
graphic breadth-first search on an undirected graph G = (V, E) in O(|V| 
+ |E|) time and space. 


Example, Let Q; denote the queue of sets of unnumbered vertices just 
before o(i) is defined in Algorithm 4.1. Figure 4.5b gives Oy, Q,, and Q, 
for the graph in Figure 4.5a. For convenience, the vertices are identified with 
their eventual position in c. Figure 4.5c shows the data structure for Q, before 
the FIX LIST has been emptied and with the implicit labels in parentheses. 

In order to use Lex BFS to recognize triangulated graphs, we need an 
efficient method to test whether or not a given ordering o of the vertices is a 
perfect vertex elimination scheme. This is proved by the next algorithm. 


Algorithm 4.2. Testing a perfect elimination scheme. 
Input. The adjacency sets of an undirected graph G = (V, E) and an ordering 
a of V. 
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a, = {1,2,3, 4, 5, 6,7, 8, 9} 
0, = {,2} < {3,4,5,6, 7 8} 


0, = {i} < {2} < {3.4.5} < {67} 


(a) (b) 


tt} {2} {34.5}  {s.7} 


(c) 


Figure 4.5. 


Output. “True” if o is a perfect vertex elimination scheme and “false” 
otherwise. 

Method. A single call to the procedure PERFECT(o), given in Figure 4.6. 
The list A(u) collects all the vertices which will eventually have to be checked 
for adjacency with u. The actual checking is delayed until the iteration when 
u = o(i) in lines 8 and 9. This technique is used so that in the o~ '(v)-th 
iteration there is no search of Adj(u). 

Complexity. Arrays are used for o and a! and lists hold Adj(v) and A(v). 
Lines 4-7 can be implemented simultaneously in one scan of Adj(v). The 
go to in line 5 will be executed exactly j — 1 times, where j is the number of 
connected components of G. The list A(u) will represent a set with repetitions. 
The test in line 8 simply checks for a vertex w on the list A(v) which is not 
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boolean procedure PERFECT (c): 
begin 
for all vertices v do A(v) —@;; 


— 


2. fori< 1ton — 1 do 
begin 
3. vp — of); 
4. X © {x € Adj(v) [a '(@) < o '(x)}; 
5. if ¥ = 2 then go to 8;; 
6. u«o(min {o '(x)|x € X}); 
7. concatenate ¥ — fu} to A(u): 
8. if A(v) — Adj(v) # @ then 
9. return “‘false”’; 
end 
10. return “true”; 
end 


Figure 4.6. Procedure to test a perfect vertex elimination scheme. 


adjacent to v, can be done in O(|Adj(v)| + |A(v)|) time by using an array 
TEST of size n initially set to all zeros as follows: 
begin 
for w € Adj(v) do TEST(w) < 1;; 
for w € A(v) do 
8. if TEST(w) = 0 then 
return “nonempty ”’; 
for w € Adj(v) do TEST(w) + 0;; 
return ‘“‘empty”’; 
end 
Thus, the entire algorithm can be performed in time and space proportional 
to 
IVI+ ¥ JAdj| + ¥ AMI, 
veV ueV 
where has A(u) is its final value. Now, the middle summand is larger than the 
last since a given Adj(v) appears as part of at most one of the lists A(u). 
Hence, both summands can be replaced by O(|E|). This proves the com- 
plexity part of the next theorem. 


Theorem 4.5. Algorithm 4.2 correctly tests whether or not an ordering o 
of the vertices is a perfect vertex elimination scheme. It can be implemented 
to run in time and space proportional to |V| + |E]. 


Proof. The algorithm returns “false” during the o~ '(u)-th iteration if 
and only if there exist vertices v, u, w (a ‘(v) < o 1(u) < o ‘(w)), where u 
is defined in line 4 during the o ‘(v)-th iteration, and 


u, we Adj(v) but u is not adjacent to w. 


Clearly, if we get “false,” then o is not a perfect elimination scheme. 
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Conversely, suppose o is not perfect elimination and the algorithm returns 
“true.” Let v be the vertex with a” '(v) largest possible such that X = {w|we 
Adj(v) and a7 1(v) < a 1(w)} is not complete. Let u be the vertex of X defined 
in line 6 during the o ‘(v)-th iteration, after which (in line 7) X — {u} is 
added to A(u). Since during the o~ '(u)-th iteration line 9 is not executed, 


every x € X — {u} is adjacent to u, 
and 
every pair x, ye X — {u} is adjacent. 
The latter statement follows from the maximality of o~ '(v). Thus, X is 
complete, a contradiction. | 


Corollary 4.6. Triangulated graphs can be recognized in linear time. 


Proof. The proof follows from Theorems 4.3-4.5. | 


5. Triangulated Graphs as Intersection Graphs 


We have seen in Chapter | that the interval graphs are a proper subclass 
of the triangulated graphs. This leads naturally to the problem of character- 
izing triangulated graphs as the intersection graphs of some topological 
family slightly more general than intervals on a line. In this section we shall 
show that a graph is triangulated if and only if it is the intersection graph ofa 
family of subtrees of a tree. (See Figure 4.7.) 


Figure 4.7. A triangulated graph and a subtree representation for it. 
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A family {7;};., of subsets of a set T is said to satisfy the Helly property if 
J < land T,0 T; # @ for alli, jeJ implies that (\,., T, # ©. 

If we let T be a tree and let each T, be a subtree of T, then we can prove the 
following result. 


Proposition 4.7. A family of subtrees of a tree satisfies the Helly property. 


Proof. Suppose T; 0 T; # @ for all i, je J. Consider three points a, b, c 
on T. Let S be the set of indices s such that T, contains at least two of these 
three points, and let P,, P,, P; be the simple paths in T connecting a with b, 
b with c, and a with c, respectively. Since T is a tree, it follows that P} A P20 
P, # @, but each T,(s € S) contains one of these paths P;. Therefore, 

(\ 2 P,nP,aP; # @. 


seS 
The lemma is proved by induction. Let us assume that 
[TAD forall ijeJJ>(\T 4D (1) 
jeJ 
for all index sets J of size < k. This is certainly true for k = 2. Consider a 


family of subtrees {T;,, ..., T;,,,}. By the induction hypothesis there exist 
points a, b, c on T such that 


k+1 


1 O They 


k kt 
ae (\T,, be (\ Ty ceT, 
j= © fags 


Moreover, every T;, contains at least two of the points a, b, c. Hence, by the 
preceeding paragraph, (\§*{ T,, # ©. | 


Theorem 4.8 (Walter [1972], Gavril [1974a], and Buneman [1974]). Let 
G = (V, E) be an undirected graph. The following statements are equivalent: 


(i) Gis a triangulated graph. 

(ii) G is the intersection graph of a family of subtrees of a tree. 

(iii) There exists a tree T = (#, &) whose vertex set % is the set of maxi- 
mal cliques of G such that each of the induced subgraphs Ty,(v € V) is con- 
nected (and hence a subtree), where %, consists of those maximal cliques 
which contain v. 

Proof. (iii) => (ii) Assume that there exists a tree T = (%, &) satisfying 
statement (iii). Let v, we V. Now 


vwekE, v,wead for some clique Ae 2%, 
Ki OAK, FD; Ty, O Tz, # DS. 
Thus G is the intersection graph of the family of subtrees {T,,.|v eV} of T. 
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(ii) > (i) Let {T,},-y be a family of subtrees of a tree T such that pwe E 
iff T, 0 T, # SO. 

Suppose G contains a chordless cycle [v9, 01, .--, U;—1, Vo] with k > 3 
corresponding to the sequence of subtrees Ty, T,,..., T,-1, To of the tree T; 
that is, T; 0 T; # © if and only if i and j differ by at most one modulo k. All 
arithmetic will be done mod k. 

Choose a point a; from T; 7 T;,, (i = 0, ..., k — 1). Let b; be the last 
common point on the (unique) simple paths from a; to a;_, and a; to'a;4,. 
These paths lie in T; and T;,,, respectively, so that b; also lies in T; 7 T;, ;. 
Let P;., be the simple path connecting b; and b;,,. Clearly P; S T;, so 
P;\P;= © for i and j differing by more than 1 mod k. Moreover, P; 4 
P,,, = {b;} fori =0,...,k — 1. Thus, (J; P; is a simple cycle in T, contra- 
dicting the definition of a tree. 

(i) = ii) ~We prove the implication by induction on the size of G. Assume 
that the theorem is true for all graphs having fewer vertices than G. If G is 
complete, then T is a single vertex and the result is trivial. If G is disconnected 
with components G,,..., G,, then by induction there exists a corresponding 
tree T; satisfying (iii) for each G;. We connect a point of T; with a point of 
T;4,;@=1,...,k — 1) to obtain a tree satisfying (iii) for G. 

Let us assume that G is connected but not complete. Choose a simplicial 
vertex a of G and let A = {a} U Adj(a). Clearly, A is a maximal clique of G. 
Let 


U = {ue A|Adj(u) < A} 
and 

Y=A-U. 
Note that the sets U, Y,and V ~— A are nonempty since G is connected but not 
complete. Consider the induced subgraph G’ = G,_y, which is triangulated 
and has fewer vertices than G. By induction, let T’ be a tree whose vertex set 


K’ is the set of maximal cliques of G’ such that for each vertex ve V — U the 
set K, = {X € K’|ve X} induces a connected subgraph (subtree) of T’. 


Remark. Either K = K’ + {A} — {Y} or K = K’ + {A} depending 
upon whether or not Y is a maximal clique of G’. 


Let B be a maximal clique of G’ containing Y. 


Case 1. If B = Y, then we obtain T from T’ by renaming B, A. 
Case 2. If B # Y, then we obtain T from T’ by connecting the new 
vertex A to B. 


In either case, K, = {A} foralluin U and K, = K;, forall vin V — A,each 
of which induces a subtree of T. We need only worry about the sets K, (y € Y). 
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In case 1, K, = K, + {A} — {B}, which induces the same subtree as K‘, 
since only names were changed. In case 2, K, = K}, + {A}, which clearly 
induces a subtree. 

Thus, we have constructed the required tree T and the proof of the theorem 
is complete. i 


Buneman [1972, 1974] discusses the application of the subtree intersection 
model in constructing evolutionary trees and in certain other classificatory 
problems. 

An undirected graph G = (V, E)is called a path graph if it is the intersection 
graph of a family of paths in a tree. Renz [1970] showed that G is a path 
graph if and only if G is triangulated and G is the intersection graph of a 
family ¥ of paths in an undirected graph such that F¥ satisfies the Helly 
property. Gavril [1978] presented an efficient algorithm for recognizing 
path graphs; he also proved a theorem for path graphs analogous to the 
equivalence of (ii) and (iii) in Theorem 4.8 (see Exercise 26). 


6. Triangulated Graphs Are Perfect 


Occasionally, the minimum graph coloring problem and the maximum 
clique problem can be simplified using the principle of separation into pieces 
(Berge [1973, p. 329]). This method is described in the following theorem and 
its proof. In particular, it is applicable to triangulated graphs. 


Theorem 4.9. Let S be a vertex separator of a connected undirected graph 
G = (V, E), and let G4,, Gy,,..., G4, be the connected components of Gy_s. 
If S is a clique (not necessarily maximal), then 


mG) = max (Gs + 4,) 


and 


o(G) = max o(Gs 4) 


Proof. Clearly x(G) > (Gg. 4,) for each i, so x(G) > k = max; 7(Gs 4 4,)- 
In fact, G can be colored using exactly k colors. First color Gs, then inde- 
pendently extend the coloring to each piece Gs, 4,. This composite will be 
a coloring of G. Thus, 7(G) = k. 

Next, certainly w(G) > (Gs, 4,) for each i, so w(G) > max; o(Gs, 4,) 
= m. Let X be a maximum clique of G, i-e., |X | = w(G). It is impossible that 
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two vertices of X lie in G4, and Gy, (i 4 j) since the vertices are connected. 
Thus, X lies wholly in one of the pieces, say Gs, 4,. Hence, m > a(Gs44,) > 
|X | = w(G).Therefore, w(G) = m. 


Corollary 4.10. Let S be a separating set of a connected undirected graph 
G = (V, E), and let G,,,G4,,..., G4, be the connected components of Gy _s. 
If S is a clique, and if each subgraph Gs, 4, is perfect, then G is perfect. 


Proof. Assume that the result is true for all graphs with fewer vertices than 
G. It suffices to show that 7(G) = w(G). Using Theorem 4.9 and the fact that 
each graph Gs, 4, is perfect, we have 


X(G) = max UGsia) = max oAGs+4,) = 0(G). | 


L L 


We are now ready to state the main result. 


Theorem 4.11 (Berge [1960], Hajnal and Suranyi [1958]). Every tri- 
angulated graph is perfect. 


Proof. Let G be a triangulated graph, and assume that the theorem is 
true for all graphs having fewer vertices than G. We may assume that G is 
connected, for otherwise we consider each component individually. If G is 
complete, then G is certainly perfect. If G is not complete, then let S be a 
minimal vertex separator for some pair of nonadjacent vertices. By Theorem 
4.1, S is a clique. Moreover, by the induction hypothesis, each of the (tri- 
angulated) subgraphs Gs, 4,, as defined in Corollary 4.10, is perfect. Thus, 
by Corollary 4.10, G is perfect. | 


Remark. The proofs in this section used only the perfect graph property 
(P,) (Berge [1960]). Histcrically, however, until Theorem 3.3 was proved, 
the arguments had to be carried out for property (P,) as well (Hajnal and 
Suranyi [1958]). 


Let Y denote the class of all undirected graphs satisfying the property that 
every odd cycle of length greater than or equal to 5 has at least two chords. 
Clearly, every triangulated graph is in Y. Our ultimate goal in the remainder 
of this section is to prove that the graphs in Y are perfect. The technique used 
to show this will be constructive in the following sense: Given a k-coloring 
of a graph Ge, we will show how to reduce it into an w-coloring of G, 
where k > w = «(G), by performing a sequence of color interchanges called 
switchings. 

Let G be an undirected graph which has been properly colored. An (a, )- 
chain in G is a chain whose vertices alternate between the colors « and f. Let 
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G,, denote the subgraph induced by the vertices of G which are colored « or p. 
An <a, B> switch with respect to G consists of the following operation: 


Either interchange the colors in a nontrivial connected component of G,, 
and leave all other colors unchanged, or recolor all isolated vertices of Gy, 
using f and leave all other colors unchanged. 


Note that the result of an <a, B> switch with respect to G is again a proper 
coloring of G. 


Lemma 4.12. Let Ge@G be properly colored, and let x be any vertex of 
G. Let vertices y, ze Adj(x) be colored « and £, respectively, with a # f. If 
y and z are linked by an (a, f)-chain in G, then they are linked by an (a, )- 
chain in Gagjx- 


Proof. Let w= [Ly = Xo, X41, X2,..-, X, = 2] be an [o, B] chain in G of 
minimum length between y and z. Clearly, / must be odd. We claim that 
{Xo X14) X25--+5 X7} S Adj(x). 

The claim is certainly true if] = 1. Let us assume that / > 3 and that the 
claim is true for all minimum (a, f)-chains of odd length strictly less than 1. 
Now, the cycle ff = [x, Xo, X1,..., X,, x] has odd length / + 2 > 5, and all 
of its chords must have x as an endpoint since a chord between an « vertex 
and a B vertex of » would give a shorter chain. Therefore, every subchain 
uLx,, x,] = Dx, ..., x,] of uw is a minimum («, f)-chain, and since Ge g the 
cycle fi has at least two chords, xx; and xx; (i < j). 

If ulxo, x;], uLx;, xj], and u[x;, x,] all have odd length, then applying the 
induction hypothesis to each of them we obtain {xo, x1, .--, X:} S Adj(x). 
Otherwise, at least one of u[xo, x;] or u[x;, x,] has even length. Without loss 
of generality, assume that p[x9, x;] has even length so that y[x;, x,] has odd 
length. By induction, {x,;, x;4;, .-., x,} S Adj(x). In particular, x;.,¢ 
Adj(x), so p[X9, X;+,] has odd length and by induction {xg, x1, .--, Xj41} 
S Adj(x). This proves the claim. | 

Let G’ = Gagy,)- Lemma 4.12 says that a nontrivial connected component 
of G,, contains only one nontrivial connected component of Gj. or only iso- 
lated « vertices of G), or only isolated f vertices of Gig. 


Lemma 4.13. Let fbe a proper coloring of a graph GeY, and let x be a 
vertex of G colored y. Let fg. be the restriction of fto the subgraph G’ induced 
by those vertices adjacent to x whose colors are from some arbitrary subset 
Q of colors with y ¢ Q. If f,- can be transformed into a coloring g’ of G’ by 
a sequence of switchings with respect to G’ (using colors from Q), then f 
can be transformed into a coloring f’ of G by a sequence of switchings with 
respect to G such that fg. = g’. 
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Proof. It is sufficient to consider the case of a single <a, B> switch with 
respect to G’, where a, 8 # y. Suppose that a connected component Hj, of 

4p Was switched. If Hj, is nontrivial, then by Lemma 4.12 the same result 
could be obtained by switching the component of G,,, containing Hj,. 
If H{, has only one vertex, then all isolated vertices of Gi, were switched to p. 
In this case the same result could be obtained by switching all nontrivial 
components of G,, which contain isolated « vertices of Gj, plus switching 
all isolated vertices of G,, to p. | 


Theorem 4.14 (Meyniel [1976]). Let Ge and let fbe a k-coloring of G. 
Then there exists a q-coloring g of G with gq = 7(G) which is obtainable from 
f by a sequence of switchings with respect to G. 


Proof. The theorem is obviously true for graphs with one vertex. Assume 
that the theorem is true for all graphs with fewer vertices than G. 
Consider a k-coloring f of G using the colors {a,,a,...,0,} withk > q = 


x(G). Choose a vertex x with color a # %, &,..., 4; if there is none, the 
proof is finished. Let G’ be the subgraph induced by the vertices colored 
01, %2,..., %, and adjacent to x. Clearly, 


q = KG) < XGaaiuw) S 9 - 1. 
Since G' € Y, the induction hypothesis implies that there exists a q'-coloring 
g' of G’ which is obtainable from f,. by a sequence of switchings with respect 
to G’. By Lemma 4.13, g’ can also be obtained from f by a sequence of switch- 
ings with respect to G. After performing this sequence of switchings, we can 
recolor x with one of the colors «,, #2,..., %, which is unused by g’ (since 
q <q -— 1). Thus, we have enlarged the set of vertices colored «,, @2,..., %,. 
Repeating this process until all vertices of G are colored 1, #2, ..., a, will 
yield a minimum coloring. i 


We are now ready to show that the graphs in @ are perfect. Gallai [1962] 
originally proved the case where each odd cycle has two noncrossing chords; 
a shorter proof appeared in Suranyi [1968]. The case where each odd cycle 
has two crossing chords was proved by Olaru [1969] (see Sachs [1970]). The 
general case, as presented here, is due to Meyniel [1976]. 


Theorem 4.15. If G is an undirected graph such that every odd cycle has 
two chords, then G is perfect. 


Proof. Let Ge¥Y with y(G) = q, and let H be an induced subgraph of G 
satisfying 
x(H) = 4, 
YH —x)=q-1 for every vertex x of H. 
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Choose a vertex x of H and a (q — 1)-coloring f of H — x, and let H’ be the 
subgraph induced by Adj,,(x). If H’ were (q¢ — 2)-colorable, then by Theorem 
4.14 f restricted to H’ could be transformed into a (q — 2)-coloring of H’ by a 
sequence of switchings with respect to H’. Then by Lemma 4.13 there would 
exist a (q — 1)-coloring of H — x using q — 2 colors for Adj,(x). But this 
would imply that y(H) = q — 1, a contradiction. 

Therefore, {x} U Adj,,(x) is not (q¢ — 1)-colorable, and hence it must be the 
entire vertex set of H. Since this argument holds for all x, it follows that H 
is a q-clique. Thus, 7(G) = w(G) = q. In like manner, y(G’) = w(G’) for all 
induced subgraphs G’ of G since being in Y is a hereditary property. Thus 
G is perfect. 


7. Fast Algorithms for the COLORING, CLIQUE, STABLE 
SET, and CLIQUE-COVER Problems on Triangulated 
Graphs 


Let G = (V, E) be a triangulated graph, and let o be a perfect elimination 
scheme for G. It was first pointed out by Fulkerson and Gross [1965] that 
every maximal clique was of the form {v} U X,, where 


X, = {xe Adj(v)|a7 '(v) < a '(x)}. 


This elementary fact is easily shown. By the definition of o, each {v} U X, 
is complete. Let w be the first vertex in o contained in an arbitrary maximal 
clique A; then A = {w} UX,,. Therefore, we have the following result. 


Proposition 4.16 (Fulkerson and Gross [1965]). A triangulated graph on 
n vertices has at most n maximal cliques, with equality if and only if the graph 
has no edges. 


It is easy enough to modify Algorithm 4.2 to print out each set {v} U X,. 
However, some of these will not be maximal, and we would like to filter them 
out. The mechanism that we employ is the observation that {u} U X, is not 
maximal iff for some i, in line 7 of Algorithm 4.2, X,, is concatenated to A(u) 
(Exercise 13). The modified algorithm is as follows: 


Algorithm 4.3. Chromatic number and maximal cliques of a trangulated 
graph. 


Input: The adjacency sets of a triangulated graph G and a perfect elimination 
scheme a. 
Output: All maximal cliques of G and the chromatic number 7(G). 
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Method: A single call to the procedure CLIQUES(o) given in Figure 4.8. The 
number S(v) indicates the size of the largest set that would have been con- 
catenated to A(v) in Algorithm 4.2. A careful comparison will reveal that 
Algorithm 4.3 is a modification of Algorithm 4.2. 


Theorem 4.17. Algorithm 4.3 correctly calculates the chromatic number 
and all maximal cliques of a triangulated graph G = (V, E) in O(|V| + |E|) 
time. 

The proof is similar to that of Theorem 4.5. 


Next we tackle the problem of finding the stability number a(G) of a tri- 
angulated graph. Better yet, since G is perfect, let us demand that we produce 
both a stable set and clique cover of size «(G). A solution is given by Gavril. 

Let o be a perfect elimination scheme for G = (V, E). We define inductively 
a sequence of vertices y,, y2,..., y, in the following manner: y, = o(1); y; is 
the first vertex in o which follows y;_, and which is not in X,,U X,,U-:- 
UX,,_,; all vertices following y, are in X,, U---U X,,. Hence 


V = {yu Vas---s Wp UXy, UU XY. 
The following theorem applies. 
Theorem 4.18 (Gavril [1972]). The set {y,, y2,..., y,} is a maximum 


stable set of G, and the collection of sets ¥, = {y,} U X,, @ = 1, 2,..., 9 
comprises a minimum clique cover of G. 


procedure CLIQUES (a): 
begin 
1. xeol; 
2. for all vertices vr do S(v) <— 0;; 
3. for i — | ton do 
begin 


4 ve ali); 

5 X < {x € Adj(v) |o-'!(v) < o 7 '(x)}; 
6. if Adj(v) = @ then print {v};; 

7. if X = @ then go to 13;; 

8 u < o(min{o~'(x) |x € X}); 

9 S(u) — max{S(u), |X] — 1}; 

0 if S(v) < |X| then do 


begin 
11. print {v} UX; 
12. x = max{y, 1+ [X}}; 
end 
13. end 
14. print ‘The chromatic number is”, y; 
end 


Figure 4.8. Procedure to list all maximal cliques of a triangulated graph, given a perfect 
elimination scheme. 
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Proof. The set {y,, y2,..., y,} is stable since if y,;y,¢ E for j < i, then 
y,€ X,,, which cannot be. Thus a(G) > ¢. On the other hand, each of the sets 
Y, = {y;} U X,, is a clique, and so {Y;,..., ¥,} is a clique cover of G. Thus, 
a(G) = k(G) = t, and we have produced the desired maximum stable set 
and minimum clique cover. | 


Implementing this procedure to run efficiently is a straightforward exercise 
and is left for the reader (Exercise 25). For a treatment of the maximum 
weighted stable set problem, see Frank [1976]. 


EXERCISES 


1. Show that for n > 5 the graph C, is not triangulated. 

2. Using Theorem 4.1, condition (iii), prove that every interval graph is 
triangulated. What is the interpretation of a separator in an interval repre- 
sentation of a graph? 

3. Prove properties (L1)-(L3) of lexicographic breadth-first search (Section 
4,3). 

4. Apply Algorithm 4.1 to the graph in Figure 3.3 by arbitrarily selecting 
the vertex of degree 2 in line 3 during the first pass of the algorithm. (i) What 
is the perfect scheme you get? (ii) Find a perfect scheme of G which cannot 
possibly arise from Algorithm 4.1. 


The class of undirected graphs known as k-trees is defined recursively as 
follows: A k-tree on k vertices consists of a clique on k vertices (k-clique); 
given any k-tree T, on n vertices, we construct a k-tree on n + 1 vertices by 
adjoining a new vertex x,,, to T,, which is made adjacent to each vertex of 
some k-clique of T;, and nonadjacent to the remaining n — k vertices. Notice 
that a 1-tree is just a tree in the usual sense, and that a k-tree has at least k 
vertices. Exercises 5-7 below are due to Rose [1974]. Harary and Palmer 
[1968] discuss 2-trees. 

5. Show that a k-tree has a perfect vertex elimination scheme and is therefore 
triangulated. Give an example of a triangulated graph which is not a k-tree 
for any k. 

6. Prove the following result: An undirected graph G = (V, E) isa k tree if 
and only if 


(i). G is connected, 
(ii) G has a k-clique but no (k + 2)-clique, and 
(iii) every minimal vertex separator of G is a k-clique. 
7, Let G=(V, E) be a triangulated graph which has a k-clique but no 
(k + 2)-clique. Prove that ||E|| < k|V| — 4k(k + 1) with equality holding if 
and only if G is a k-tree. 
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8. Show that every 3-tree is planar. 

9. Let G be an undirected graph and let H be constructed as follows. The 
vertices of H correspond to the edges of G, and two vertices of H are adjacent 
if their corresponding edges form two sides of a triangle in G. Prove that G 
is a 2-tree if and only if H is a cactus of triangles. 

10. Show that every vertex of a minimal x—y separator is adjacent to some 
vertex in each of the connected components containing x and y, respectively. 
11. Let S be a minimal x—y separator of a connected graph G. Show that 
every path in G from x to y contains a member of S and that every seS is 
contained in some path yp from x to y which involves no other element of S, 
that is, uO S = {s}. 

12. Prove the following: For. any minimal vertex separator S of a triangu- 
lated graph G = (V, E), there exists a vertex c in each connected component 
of Gy_s such that S < Adj(c). (Hint: Prove the inclusion for each subset 
X G& S using induction.) 

13. Program Algorithms 4.1 and 4.2 using the data structures suggested and 
test some graphs for the triangulated graph property. 

14. Give a representation of the graph in Figure 4.5a as intersecting sub- 
trees of a tree. 

15. Prove that G is triangulated if and only if G is the intersection graph of a 
family 7 of subtrees of a tree where no member of 7 contains another 
member of F (Gavril [1974a]). 

16. Give an algorithm which constructs for any triangulated graph G a 
collection of subtrees of a tree whose intersection graph is isomorphic to G. 
17. Prove the following: H is a tree if and only if every family of paths in H 
satisfies the Helly property. 

18. Prove the following theorem of Renz [1970]: G is the intersection graph 
of a family of paths in a tree iff G is triangulated and is the intersection| 
graph of a family of arcs of a graph satisfying the Helly property. 

19. Using the Helly property for subtrees of a tree, show directly that (ii) 
implies (iii) in Theorem 4.8. (Hint: for each clique A of the intersection 
graph, paint the subtree corresponding to the intersection of all members of 
A red and paint the remainder of the tree green. What does it look like when 
you collapse each red piece to a point?) 

20. Prove Corollary 4.10 using the perfect graph property (P,) instead of 
(P;). 

21. The line graph L(G) of G is defined to be the undirected graph whose 
vertices correspond to the edges of G, and two vertices of L(G) are joined by 
an edge if and only if they correspond to adjacent edges in G. Prove that G is 
triangulated if and only if L(G) is triangulated. 
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22. Prove that Algorithm 4.3 correctly calculates the chromatic number and 
all maximal cliques of a triangulated graph. 

23. Let o be a perfect vertex elimination scheme for a triangulated graph 
G = (V, E). Let H = (V, F) be an orientation of G, where xye F iffo™ 1(x) 
< a” '(y). Show that H is acyclic. Let t be any topological sorting of H. Show 
that t is also a perfect elimination scheme for G. 

24. Prove that a height function h (see Chapter 2, Exercise 8) of the acyclic 
oriented graph H defined in the preceding exercise is a minimum coloring of 
the triangulated graph G. Thus, a triangulated graph can be colored with a 
minimum number of colors in time proportional to its size. 

25. Modify Algorithm 4.3 so that, in addition, it prints out a maximum 
stable set and prints an asterisk next to those cliques which together comprise 
a minimum clique cover. 

26. Prove the following: G = (V, E) is a path graph if and only if there 
exists a tree T whose vertex set is # (the maximal cliques of G) such that for 
all ve V, the induced subgraph T,, is a path in T. (#,, denotes the set of 
maximal cliques which contain v.) (Gavril [1978].) 

27. Let G = (V, E) be an undirected graph, and let o = [v,, v2,..., v,] be 
an ordering of V. Consider the following property: 

(T): If o '(u) <a 1) < o '(w) and we Adj(u) — Adj(v), then there 
exists an x such that 0 '(v) < a (x) and x € Adj(v) — Adj(w). 

Prove that if G is a triangulated graph and o satisfies (T), then o is a perfect 
elimination scheme for G (Tarjan (1976]).) 

28. (i) Prove that any MCS order, as defined at the end of Section 4.3, 
satisfies property (T) from the preceding exercise. 

(ii) Give an implementation of MCS to recognize triangulated graphs in 

O(n + e) time. (Hint. To achieve linearity you may wish to link together all 
unnumbered vertices which are currently adjacent to the same number of 
numbered vertices (Tarjan [1976]).) 
29. An undirected graph is called i-triangulated if every odd cycle with more 
than three vertices has a set of chords which form with the cycle a planar 
graph whose unbounded face is the exterior of the cycle and whose bounded 
faces are all triangles. Prove that a graph is i-triangulated if and only if every 
cycle of odd length k has k — 3 chords that do not cross one another (Gallai 
[1962]). 
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CHAPTER 5 


Comparability Graphs 


1. I-Chains and Implication Classes 


This chapter is devoted to the class of perfect graphs known as com- 
parability graphs or transitively orientable graphs. These graphs were en- 
countered in Section 1.3 in connection with interval graphs (Proposition 1.3), 
but our treatment here will be independent of that brief introduction. 

An undirected graph G = (V, E) is a comparability graph if there exists an 
orientation (V, F) of G satisfying 


FOF =, FtF'=6 FCF, 


where F? = {ac|ab, bce F for some vertex b}. The relation F is a strict 
partial ordering of V whose comparability relation is exactly E, and F is 
called a transitive orientation of G (or of E). Comparability graphs are also 
known as transitively orientable graphs and partially orderable graphs. 
Examples of some comparability graphs can be found in Section 1.3. 

Let us see what happens when we try to assign a transitive orientation to 
the 4-cycle (Figure 5.1a). Arbitrarily choosing ab € F forces us to orient the 
bottom edge toward b and the top edge toward d (for otherwise transitivity 
would be violated). These in turn, force the remaining edge to be oriented 
toward d. Applying the same idea to the graph in Figure 5.1b, we find that a 
contradiction arises, namely, choosing ab € F forces successively the orienta- 
tions cb, cd, cf, ef, bf, and ba. This graph is not a comparability graph. We now 
make the notion of forcing more precise. 

Define the binary relation T’ on the edges of an undirected graph G = 
(V, E) as follows: 


: either a=a' and bb'¢€E 
bT a'b’ ff 
oe _ b= b' and aa'¢E 
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— 


(a) (b) 


Figure 5.1. Examples of forcing. The arbitrary choice of ab € F forces the other indicated 
orientations. 


We say that ab directly forces a’b' whenever ab I a’b’. Since E is irreflexive, 
ab T ab; however, abY ba. The reader should not continue until he is con- 
vinced of this fact. 

The reflexive, transitive closure I’* of Fis easily shown to be an equivalence 
relation on E and hence partitions E into what we shall call the implication 
classes of G. Thus edges ab and cd are in the same implication class if and only 
if there exists a sequence of edges 

ab = a9b) T a,b, ---T a,b, = cd, with k > 0. 


Such a sequence is called a I’-chain from ab to cd, and we say that ab (eventu- 
ally) forces cd whenever ab I* cd. 
The reader can easily verify the properties 


ab TV a'b' = baT b’a’, 
ab T* a'b' = baI* b’a’, 
which follow directly from the definitions. 
Let .¥(G) denote the collection of implication classes of G. We define 
I(G) = {A|Ae A(G)}, 


where A = AU A7! is the symmetric closure of A. The members of .¥(G) 
are called the color classes of G for reasons that will become evident later. 


Examples. The graph G in Figure 5.2 has eight implication classes: 
A, = {ab}, A, = {cd}, A; = {ac, ad, ae}, Ag = {be, bd, be}, 
Ay! = {ba}, Az! = {de}, A3' = {ca,da,ea}, Ag’ = {cb, db, eb}. 


So we have (G) = {4,, A,, A3, Ag}. On the other hand, the graph in Figure 
5.1b has only one implication class: 


A = {ab, cb, cd, cf, ef, bf, ba, be, dc, fc, fe, fb} 
and A = A. 
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a a 
A WP, 
th S “n, 
ae a 
b b 


Figure 5.2. An undirected graph G and a coloring of its edges according to the classes 
of 4(G). 


Theorem 5.1. Let A be an implication class of an undirected graph G. If 
G has a transitive orientation F, then either F 0 A = AorF 1 A = A ‘and, 
in either case, AM A = @. 


Proof. We defined T in order to capture the fact that, for any transitive 
orientation F of G, 
if abfa’b’ and abeF, then a'b’cF. 
Applying this property repeatedly, we obtain F 7 A = @or A ¢ F. Since (i) 
ACF + F ‘and (ii) F \ F-! = @, we have the implications 
FAA=@=>ACF! | [by(i] 
=A 1CF>FOA=A"}, 


and 
ACF =A'CF 'SFHA'=Q [by (i)] 
=>FOA=A. 
In either case AN A71 = @. | 


The converse of Theorem 5.1 is also valid, namely, if AM A~* = @ for 
every implication class A, then G has a transitive orientation. This result will be 
proved as part of Theorem 5.27. Theorem 5.27 also provides the justification 
for an algorithm which assigns a transitive orientation to a comparability 
graph. 


Remark. Many readers may wonder whether an arbitrary union of im- 
plication classes F = |); A; satisfying F 0 F-' = @ and F + F"' = Eis 
necessarily a transitive orientation of G. The answer is no. As a counter- 
example, consider a triangle which has 8 = 2? such orientations, two of 
which fail to be transitive. 


Next we present two lemmas which will be useful throughout this chapter. 


Let ab = agby T a,b, ---T a,b, = cd be given. For eachi = 1,...,k we 
have 


a;_ 1b; , Va,b;- , T a;b;, 
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Figure 5.3. 


since the added middle edge equals one of the other two. Hence we may state 
the following: 


Lemma 5.2. If ab I’* cd, then there exists a T-chain from ab to cd of the 
form 


ab = dgb) T a,b) T a,b, T a,b, T---T a,b, = cd. 


Such a chain will be called a canonical T-chain. 


Lemma 5.3 (The Triangle Lemma). Let A, B, and C be implication classes 
of an undirected graph G = (V, E) with A 4 B and A # C“' and having 
edges ab € C, ac € B, and bc € A (see Figure 5.3). 


Gi) If b’c’e A, then ab’ eC and ac’ e€ B. 
(ii) If b’c’e A and a’b’ eC, then a’c'€ B. 
(iii) No edge in A touches the vertex a. 


Proof. By Lemma 5.2 there exists a canonical I’-chain 
be = bo¢o V byco T bye, --- Tb, c, = be’. 
By induction on i, we have the following implications: 
[B 3ac;,X b;,.,¢;¢€ A] > ab;,,€E, 
b;+1b;¢ E => ab;, , DabjeC, 
[C713 bj4 a ¥ bjs 16441 € A] > ac;,,€ E, 
C410; ¢ E => ac;,, Tl ac;,e B. 
Therefore, in particular, ab’ = ab, €C and ac’ = ac, € B. This proves (1). 


Next, let us assume that b’c’ € A and a’b’€ C. By part (i), ac’ € B. Consider 
a new canonical [’-chain, 


ab = agbo T a,bo T a,b, T---T a,b, = a'b’. 
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This chain gives rise to the chain 
a’ =ageTa’T--- Tae =a’. 


Thus, ac’ 1* a’c’ and a’c' € B, which proves (ii). 
Finally, part (i) immediately implies (iii). | 


Theorem 5.4. Let A be an implication class of an undirected graph G = 
(V, E). Exactly one of the following alternatives holds: 


(i) A=A=A7; 
(ii) ANA 1=@, A and A”! are transitive, and they are the only 
transitive orientations of A. 


Proof. (i) Assume An A! 4 @. Let ahe AN A” !, so abT* ba. For 
any cde A, cdl * ab and dcI* ba. Since I'* is an equivalence relation, 
cd * de and dee A. Thus A = A. 

(ii) Assume Am A! = @ and let ab, bce A. Now ac¢ E> abl ch> 
che A => bee A~', a contradiction. Thus ac eé E. 

Let B be the implication class of G containing ac, and suppose A # B. 
Since A # A7' and abe A, the Triangle Lemma 5.3(i) implies that ab € B, a 
contradiction. Thus ac € A, and A is transitive. Moreover, A being transitive 
implies that A~! is transitive. 

Finally, A is an implication class of A, so by Theorem 5.1 A and A~ ! are the 
only transitive orientations of A. | 


Corollary 5.5. Eachcolor class of an undirected graph G either has exactly 
two transitive orientations, one being the reversal of the other, or has no 
transitive orientation. Ifin G there is a color class having no transitive orienta- 
tion, then G fails to be a comparability graph. 


2. Uniquely Partially Orderable Graphs 


Let Hy be a graph with n vertices v,, v,,..., v, and let H,, H2,..., H,, be 
n disjoint graphs.* The composition graph H = Ho[H,, H2, ..., H,] is 
formed as follows: For all 1 < i,j < n, replace vertex v; in Hy with the graph 
H, and make each vertex of H; adjacent to each vertex of H; whenever »; is 


* The graphs may be directed or undirected. 
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Phy Ky Gl 


Figure 5.4. The composition of some undirected graphs. 


adjacent to v; in Ho. Formally, for H; = (V,, E;) we define H = (V, E) as 
follows: 


Ves 


i>1 


E= \JE,u {xy|xe\, ye V,and 0,0; € Eo}. 
i>t 
We may also denote E = E,[E,, Ep, . 


.., E,]. We call Ho the outer factor and 
Hy,,. 


.., H,, the inner factors (see Figures 5.4 and 5.5). 


Theorem 5.6. Let G = G,[G,, G., ..., G,], where the G, are disjoint 


undirected graphs. Then G is a comparability graph if and only if each G; 
(O < i < n) is acomparability graph. 


4 2 
N ‘\ yp aS 
4 3 

6 A f f h 


Fo [Fur fr Fx: 4] 


Figure 5.5. The composition of some transitively oriented graphs. 
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Figure 5.6. Three decompositions of the same graph. The edges are marked according to 
their color classes. 


Proof. Let Fo, F,,..., F, be transitive orientations of Go, G,;,..., G,, 
respectively. It is easy to show that Fo[F,,..., F,,] is a transitive orientation 
of G. The converse follows from the hereditary property of comparability 
graphs. | 


A graph is called decomposable if it can be expressed as a nontrivial com- 
position of some of its induced subgraphs; otherwise, it is called indecompos- 
able. Three decompositions of the same graph are illustrated in Figure 5.6. 
Of course, any graph G has the trivial decompositions G = K,[G] and G = 
G[K,, K,,..., K,]. Formally, G = (V, E) is decomposable if there exists a 
partition V = V, + V, +----+ V, of the vertices into nonempty pairwise 
disjoint subsets with 1 < r < |V| such that 


G = GRlGy,; Gy,, ary Gy] 


for any set of representatives R = {x,,xX2,...,X,}, x;€ Vj. Such a partition is 
said to induce a proper decomposition of G. Theorem 5.6 may be reinterpreted 
as follows. 


Corollary 5.7. Let F be a transitive orientation of a comparability graph 
G. If G = Gal Gy,, ..., Gy,] is a proper decomposition of G, then F = 
FR[Fy,,---» Fy]. 

Let us examine the effect of this decomposition on the color classes. Notice 
in Figure 5.6 that each color class occurs either entirely within one internal 
factor or entirely within the external edges. This phenomenon is true in 
general. 


Theorem 5.8. Let G = G,[G,, ..., G,] be the composition of disjoint 
undirected graphs G; = (V,, E;)(i = 0,1,...,n). If A is a color class of G, then 
one of the following alternatives holds: 

(1) A & E, for exactly one index j > 1, or 

Gi) ANE; = © for all indices j > 1. 
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Proof. By our original definition of forcing, every color class A is a con- 
nected (partial) subgraph of G. Suppose that An E; # @ for some j > 1. 
Let abe An E, and consider an edge a’b’T ab. Clearly ab'¢E, for any 
k #j, k > 1, since edges in different internal components never share a 
vertex. Moreover, a’b’ cannot be an external edge because if it were then by 
the definition of composition the vertices a, a’, b, b’ would induce a triangle 
in G, implying that a’b’ ¥' ab. Hence, a’b’ must also be in E;. Thus, by con- 
nectivity, A © E;. | 


Let G = (V, E) be an undirected graph. A subset Y ¢ V is called partitive 
if for each xe V — Y either Y ~ Adj(x) = @ or Y © Adj(x). A partitive 
set Y is nontrivial if 1 < | Y| < |V]|.On the one hand, any internal factor ofa 
decomposition of G is partitive. On the other hand, a partitioning of the 
vertices V = {v,} + --- + {v,} + Y where Y is partitive induces a proper 
decomposition of G. Therefore, we may conclude the following remark. 


Remark 5.9. G has a nontrivial partitive set if and only if G is decomposable. 


Before continuing, we present two simple consequences of the Triangle 
lemma. 


Proposition 5.10. If Y is the set of vertices spanned by a color class A of 
an undirected graph G = (V, E), then Y is partitive. 


Proof. If Y = V, then the result is trivial. Otherwise, let ae V — Y, and 
suppose that be Y m Adj(a). Then, abe E — A and bce A for some ce Y, 
which implies that ace E — A. Applying Lemma 5.3(i), we obtain that 
Y c Adj(a). | 


Proposition 5.11. An undirected graph G = (V, E) may have at most one 
color class which spans all of V. 


Proof. Suppose that two distinct color classes A and B both span V. Then 
for every vertex b there exist edges ab e B and bce A. Since A ¥ B, the edge 
ac is in E. What color is it? Let C denote the color class containing ac. If 
C # A,then Lemma 5. 3(ii) implies that no edge from A may touch vertex a,a 
contradiction. Hence C = A ¥ B, and Lemma 5.3(iii) now implies that no 
edge from B may touch vertex c, another contradiction. Therefore, A and B 
cannot both span all of V. I 


A comparability graph G is called uniquely partially orderable (UPO) if it 
has exactly two transitive orientations, one being the reversal of the other. 
Clearly, a comparability graph is UPO if and only if it has exactly one color 
class (see Corollary 5.5). 
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Theorem 5.12 (Shevrin and Filippov [1970]; Trotter, Moore, and 
Sumner [1976]). Let G be a connected comparability graph. The following 
conditions are equivalent. 


(i) Gis UPO. 
(ii) Every nontrivial partitive set of G is a stable set. 
(iii) For every proper decomposition of G, each internal factor is a stable 
set (i.e., all edges are external). 


Proof. The following proof is due to Arditti [1976a]. By the comments 
preceding Remark 5.9, (ii) and (iii) are equivalent. If G is UPO, then G has 
exactly one color class, and this class spans V. Therefore, by Theorem 5.8 
any proper decomposition of G must make all edges external. Thus (i) implies 
(iii). Next, suppose G is not UPO; then by Proposition 5.11 G has a color 
class which only spans a proper subset Y of V. By Proposition 5.10, Y is a 
nontrivial partitive set which is not a stable set. Thus (ii) implies (i). | 


Corollary 5.13. Let G be a comparability graph. If G is indecomposable, 
then G is UPO. 


Proof. If G is indecomposable, then G is connected and it satisfies condi- 
tion (i11) of Theorem 5.12 vacuously. Hence G is UPO. | 


3. The Number of Transitive Orientations 


In this section we shall examine the interaction between implication 
classes. In the process we will obtain a formula for the number ¢(G) of transi- 
tive orientations of a comparability graph G and a procedure for constructing 
them. Our treatment follows Golumbic [1977a], in which most of this theory 
was developed. An alternate method for calculating t(G) appears in Shevrin 
and Filippov [1970]. 


Example. A transitive orientation of any graph partially orders its 
vertices. Consider a transitive orientation F of the complete graph K,,, on 
r + 1 vertices. Since in F each pair of distinct vertices is comparable, the 
partial ordering is actually a linear ordering (total ordering). Conversely, any 
linear ordering of the vertices of K,,, yields a transitive orientation by direct- 
ing each edge from smaller to larger. Therefore, 


t(K,,,) = the number of linear orderings of r + 1 elements 
=(r+ 1)! 
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Let G = (V, E) be an undirected graph. A complete subgraph (Vs, S) on 
r + 1 vertices is called a simplex of rank r if each undirected edge ab of S is 
contained in a different color class of G. For example, each undirected edge 
ab of E is itself a simplex of rank 1. A simplex is maximal if it is not properly 
contained in any larger simplex. 

The multiplex generated by a simplex S of rank r is defined to be the follow- 
ing undirected (partial) subgraph: (V,, M), where 


M = {abe E|abT* xy for some xye S$}, 
or alternatively, 
M=(UA, 

where the union is over all color classes 4 € A(G) satisfying AAS # ©. 
Thus, M is the union of the 47(r + 1) color classes represented by the edges of 
the simplex S. (This number is due to S being a complete graph on r + 1 
vertices.) Anticipating Corollary 5.15 we say that the multiplex M also has 
rank r. A multiplex is maximal if it is not properly contained in any larger 


multiplex. We will soon see that M is a maximal multiplex if and only if S isa 
maximal simplex. 


Remark. If we actually assign a different color to each class of .#(G) and 
paint the edges of G accordingly, then a complete subgraph S whose edges 
are each painted a different color is a simplex. The collection of edges of E 
painted the same color as some edge of S is a multiplex. For example, if there 
is a red, white, and blue triangle in the graph, then the set of all red, white, and 
blue edges is a multiplex of rank 2. The graph in Figure 5.2 has two disjoint 
maximal multiplexes, one of rank 2 and one of rank 1. The expressions 
tricolored triangle and simplex of rank 2 are synonymous. Finally, notice that 
the edges and implication classes of a tricolored triangle satisfy the hypotheses of 
the Triangle Lemma 5.3. 


An isomorphism between two simplices (V,, S,) and (V,,S,) of an undirected 
graph is a bijection f: V, > V, such that ab T* f(a) f(b) for each distinct pair 
a, be V,. It is thus possible to lay S, on top of S, so that the colors of their 
edges match. 


Theorem 5.14 (Golumbic [1977a]). Let (V;, T) be a simplex generating 
the multiplex M, and let (Vy, S) be a simplex contained in M. Then (Vg, S) is 
isomorphic to a subsimplex of (V7, T). 


Proof. Choose an edge bc € S. Since T generates M, there exists an edge 
b’c'e T such that bc T* b’c’. Define f(b) = b’ and f(c) = c’. If rank S = 1, 
then the theorem is proved. 
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Figure 5.7.. From a tricolored triangle in S we find an isomorphic tricolored triangle in 7. 
The vertices 5’ and b” must be equal since Tis a simplex. 


Otherwise, consider any other vertex a € Vy, and let A, B, and C denote the 
implication classes such that bc € A, ac € B, and ab € C. Since T generates M, 
there exists an edge a”b” e T 1 C. Applying the Triangle Lemma 5.3(i) twice 
we obtain (1) ab’ e C and ac’ € B and (2) ac’ € Band b’ce A (Figure 5.7). But 
the simplex T cannot contain two different edges b’c’ and b’c' which are the 
same color; hence b’ = b”. Define f(a) = a”. In this manner fis defined for all 
vertices of V;. Choose distinct vertices a and d of Vs, different from b and c. 
Since abI* f(a) f(b) and dbT* f(d) f(b), then f(a) = f(d) would imply 
a = d, since Sis a simplex. Thus fis injective. Moreover, the Triangle Lemma 
5.3(ii) implies that ad ’* f(a) f(d). Therefore, fis an isomorphism from S to a 
subsimplex of T. | 


The following is an immediate result of the preceding theorem. 


Corollary 5.15. Simplices generating the same multiplex are isomorphic. 

The next lemma shows us how to construct simplices. 

Lemma 5.16. Let(V;, S) be a simplex of an undirected graph G = (V, E) 
generating a multiplex M. If G contains a tricolored triangle on vertices a, b,c 


such that ab ¢ M but bce M, then we may adjoin the vertex a to (Vs, S) to 
obtain the larger simplex (V;, T) containing (Vs, S), where 


Vy fe Vsu {a}, 
T =S vu {ad|de Ve}. 
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Proof. Let us assume that G contains a tricolored triangle on a, b, c satisfy- 
ing ab¢ M and bce M. Since S generates M, there is some edge b’c' € S for 
which b’c’ [* be. The Triangle Lemma 5.3(i) implies that ab’ and ac’ are in 
the same two distinct color classes of G, respectively, as are ab and ac. Thus, 
ab’ ¢ M. Next we shall show that ac’ ¢ M as well. 

Suppose that ac’ € M; then ac’ I’* xy for some xy € S (because ac’ must be 
the same color as some edge in S). Again by the Triangle lemma, b’a ’* b’x, 
however, b’a ¢ M while b'x € S, a contradiction. Thus, ac’ ¢ M. This argument 
actually proves the stronger claim: 


Fact 1. Ifa tricolored triangle has one side in M and another side not in 
M, then the third side is also not in M. 


Next let de Vy, d # b’,c’. Certainly ade E since ab’ and b'd are in different 
color classes. Whereas the edges b’c and c’d are in different color classes, the 
edge ad is in a different class than at least one of them. Therefore, at least one of 
the triangles G,, 4,4; OF Gia,e',4 18 tricolored and satisfies the hypothesis of 
Fact 1, implying that ad ¢ M. Thus, the set {ad|d € V,} shares no color classes 
with S. 

Since ab’ and ac’ are in different color classes, to conclude the proof that 
(V;, T) is a simplex it suffices to show the following claim: 


Fact 2. Either the undirected edges ad (for d € Vs) are all in different color 
classes, or all of the edges ad (for de V,) are I’*-related. 


Suppose that ad, ad’ ¢ A € 4G). If A has no transitive orientation, then 
Theorem 5.4(i) implies that ad D'*ad’. If A has a transitive orientation, then 
Theorem 5.4(ii) implies that ad * ad’ since dd’ ¢ A. Now let d” be any vertex 
of Vz other than d or d’. If ad” ¢ A, then Gia,a,a) ANd Gig gay, are both tri- 
colored triangles sharing two common colors. So by the Triangle Lemma 
5.3(i), dd” T’* d'd”, which contradicts the definition of a simplex. Thus, 
ad” € A and, as before, ad * ad”. This proves Fact 2 and concludes the proof 
of the theorem. Obviously, rank T = 1 + rank S. | 


Lemma 5.3(ii) tells us that if an undirected graph contains a red, white, and 
blue triangle, then anywhere in the graph where we find a red edge ab and a 
white edge bc, the edge ac will be blue. Suppose there is a multiplex M con- 
taining a red, white, and blue triangle. The next theorem shows, in particular, 
that every red, white, and blue triangle is part of a simplex generating M. 


Theorem 5.17 (Golumbic [1977a]). Let S be a simplex contained in a 
multiplex M. There exists a simplex Sy generating M such that S c Sy. 
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Proof. If rank S = rank M, then S itself generates M. We proceed by 
reverse induction, assuming the theorem to be true for any simplex of rank 
greater than rank S. 

Let U be any simplex generating M. Since rank U = rank M, only some 
of the edges of U have “cousins” in S of the same color. These are the ones 
contained in M ,, defined here as the multiplex generated by S. Thus M, c M. 
Since U is connected it has a tricolored triangle on a, b, c with bee M,, 
ab ¢ M,. By Lemma 5.16, we can adjoin the vertex a to S creating a simplex 
T containing S with rank T = 1 + rank S. Thus, by induction, there is a 
simplex Sy generating M such that S c T © Sy. i 


Theorems 5.14 and 5.17 can be summarized as follows: 


Corollary 5.18. Let M,, M, be multiplexes with M, © M,. 


(i) Every simplex generating M, is contained in a simplex generating 
M, . 

(ii) Every simplex generating M, contains a subsimplex which generates 
M,. 


Theorem 5.19. Let M be the multiplex generated by a simplex S. Then, M 
is a maximal multiplex if and only if S is a maximal simplex. 


Proof. (=>) This implication follows directly from the definition of 
multiplex. 

(<=) Suppose S is maximal and M < M’, where M' is another multiplex. 
Since S © M © M’, Theorem 5.17 implies the existence of a simplex S’ con- 
taining S with S’ generating M’. But the maximality of S yields S = S’, so 
M=M«'. | 


By virtue of the preceding theorem and corollary we can now locate a 
maximal multiplex by a local search of the edges. We pick an edge at random 
and build up successively large simplices each containing its predecessor until 
the simplex we have is maximal. It then generates a maximal multiplex. 

The next theorem implies that the maximal multiplexes partition the edges 
of G. 


Theorem 5.20. If M, and M, are maximal multiplexes of an undirected 
graph G, then either M, 0 M, = @ or M, = Mj. 

Proof. Let S, and S, be simplices generating M, and M,, respectively. By 
Theorem 5.19, S, and S, are maximal. Suppose M, 0M, # @ and M, 
# M,, then some edges of S, are in M, and some are not. Because S, is 
connected, it must contain a tricolored triangle G,,,,., with bee M, and 
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ab ¢ M,. By Lemma 5.16, we can construct a large simplex T containing S,, 
contradicting the maximality of S,. Thus, one of the alternatives of the 
theorem must hold. | 


Theorem 5.21. If A is an implication class of an undirected graph G = 
(V, E) such that A = A, then A itself is a maximal multiplex of rank 1. 


The proof of Theorem 5.21 follows directly from the Triangle lemma and 
the definition of multiplex. It is left as an exercise for the reader. | 


A simplex of rank r has (r + 1)! transitive orientations, as we have seen in 
the example at the beginning of this section. Moreover, in the proof of the 
next theorem we will show that a transitive orientation of the simplex extends 
uniquely to a transitive orientation of the multiplex generated by it, except 
when the multiplex is itself an implication class and hence not transitively 
orientable (by Theorem 5.4). Conversely, a transitive orientation of a multi- 
plex restricts uniquely to a transitive orientation of any simplex contained 
in it. 


Theorem 5.22. Let M be a multiplex of rank r. If M is transitively orient- 
able, then ((M) = (r + 1)! 


Remark. Theorem 5.21 shows that the only case in which M might fail to 
be transitively orientable is when r = 1. 


Proof. Let S bea simplex of rank r generating M, and let Fs bea transitive 
orientation of S. Finally, let A,,..., A, [k = 4r(r + 1)] be the implication 
classes containing the edges of F,. The corresponding color classes A; are 
distinct, and A, + --- + A, = M.Ifr = 1, then A, isa transitive orientation 
of M = A, if and only if A, 4 A, if and only if «(M) = 2. If r > 1, then 
F=A,+-:-+ A, is certainly an orientation of M by Theorems 5.4 and 
5.21. We must show that F is transitive. Let ab e€ A;, bc € Aj. If i = j, then 
ac € A, by the transitivity of A; [Theorem 5.4(i)]. If i # j, then ac € E since 
A; A j = ©. Suppose cae F, then the individual transitivity of A; and A; 
implies that cae A, for some i # t 4 j. Theorem 5.14, however, implies that 
there exist edges a’b’, b’c’, c'a’ eS such that ab’ € A;, b’c'€ A;, and c'a'€ A,, 
contradicting the transitivity of F';. Therefore, ac € F and F is transitive. Thus, 
for each transitive orientation of S we obtain a unique transitive orientation 
of M,so t(M) > tS) =(r + LD! 

Conversely, given a transitive orientation F, of M, consider its restriction 
F, 0S to S. The three facts, ab, bc € F, 7 S, F, being transitive and S being 
complete, collectively imply that ace F,™S. So F,S is a transitive 
orientation of S. Therefore, t(S) = t(M) and Theorem 5.22 is proved. | 
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The partition of an undirected graph G = (V, E) into its maximal multi- 
plexes E = M, +--- + M, will be referred to as its M-decomposition. It is 
unique up to the order of the M;. Having just examined the transitive 
orientability of a multiplex, let us now investigate the transitive orientability 
of all of E. The next major theorem shows a one-to-one correspondence 
between the transitive orientations of the M, and those of E. 


Theorem 5.23 (Golumbic [1977a]). Let G =(V, E) be an undirected 
graph, and let E = M, + --- + M,, where each M; is a maximal multiplex 
of E. 

(i) IfF isa transitive orientation of G, then F 4 M, isa transitive orienta- 
tion of M;. 

(ii) IfF—,,..., F,are transitive orientations of M,,..., M,, respectively, 
then F, + --- + F, is a transitive orientation of G. 

(ili) t(G) = t(M,)t(M)--- t(M,). 

(iv) If G is a comparability graph and r; = rank M,, then t(G) = 

k 

i-y + LD! 


Proof. Statement (iii) follows from (i) and (ii), while (iv) is implied by (iii) 
and Theorem 5.22. 


(i) Assume F is a transitive orientation of G and let ab, be e F ~ M;. 
Suppose that ac ¢ M;; then G,, ,, , must not bea tricolored triangle. Therefore, 
ab, bce A for some A €.A(G). Thus ab, bce F 7 A, and F 4 A equals either 
A or A~'*, both of which are transitive by Theorems 5.1 and 5.4. Hence 
ac € A, which is a contradiction. 

(ii) Assume that F,,..., F, are transitive orientations of M,,..., M,, 
respectively. We shall show that F, + ---+ F, is transitive. Let abe F,, 
bee F,. If i = j, then ac F; by transitivity of F;. If i # j, then ab and be are 
in different color classes, so ace E. Since G,,,,., cannot be a tricolored 
triangle and hence cannot be contained in a single multiplex, it follows that 
ace M; + M,. But if cae F; + F;, then transitivity gives a contradiction. 
Thus, ac € F; + F;. a 


Summarizing the results of this section, we have shown that the maximal 
multiplexes partition the edges and act independently with respect to transi- 
tive orientation. They are generated by maximal simplices which can be 
built up from a single edge by a local search. Simplices generating the same 
multiplex are isomorphic. Finally, the number of transitive orientations of an 
undirected graph is a product of factorials depending on the ranks of its 
maximal multiplexes. Thus, every comparability graph behaves as if it were 
a disjoint collection of complete graphs. 
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4. Schemes and G-Decompositions—An Algorithm 
for Assigning Transitive Orientations 


In this section we describe an algorithm for calculating transitive orienta- 
tions and for determining whether or not a graph is a comparability graph. 
This technique is a modification of one first presented by Pnueli, Lempel, 
and Even [1971]. Our version uses the notions introduced in Section 5.1; the 
proof of its correctness relies on some of the results of Section 5.3. A discussion 
of its computational complexity will follow in Section 5.6. 

Let G = (V, E) be an undirected graph. A partition of the edge set E = 
B, + B, +---+ B, is called a G-decomposition of E if B, is an implication 
class of B, + --- + B, for all i = 1, 2,..., k. A sequence of edges [x,y,, 
X2 V2, +--+, Xx ¥,]} 18 called a decomposition scheme for G if there exists a G- 
decomposition E = B, + B, +--- + B, satisfying x,y,¢B, for all i= 
1,2,...,k. In this chapter the term scheme will always mean a decomposition 
scheme. 

For a given G-decomposition there will be many corresponding schemes 
(any set of representatives from the B,). However, for a given scheme there 
exists exactly one corresponding G-decomposition. A scheme and G-decom- 
position can be constructed by the following procedure: 


Algorithm 5.1 (Decomposition Algorithm). 
Let G = (V, E) be an undirected graph. 
Initially, let i = 1 and E, = E. 


Step (1): Arbitrarily pick an edge e; = x,y, € E;. 

Step (2): Enumerate the implication class B; of E; containing x; y,. 

Step (3): Define E,,, = E; — B;. 

Step (4): If E;,, = @, then let k = i and Stop; otherwise, increase i by 1 
and go back to Step (1). 


Clearly, the decomposition algorithm yields a scheme [x,);,.-., XV] 
and corresponding G-decomposition B, + --- + B, for any undirected graph 
G. Moreover, if y,x; had been chosen instead of x;y; for some i, then B; ' 
would replace B, in the G-decomposition. Applying the algorithm to the 
graph in Figure 5.2, the scheme [ac, bc, dc] gives the G-decomposition for 
which B, = A;, B, = A, + A; ' and B; = Ay' (see p. 106 and Figure 5.8*). 
In this example notice that although ba and bc were not I-related in the 
original graph, once B, is removed they become I-related in the remaining 
subgraph and their implication classes merge. In general, each implication 


* Another example is given in Exercise 8. 
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Figure 5.8. An illustration of the decomposition algorithm. 


class of E; , , will be the union of some number of implication classes of E;. We 
now examine exactly how the old classes merge. 


Theorem 5.24 (Golumbic [1977a]). Let A be an implication class of an 
undirected graph G = (V, E), and let D be an implication class of E — A. 
Either 

(i) Dis an implication class of E, and A is an implication class of E — D, 
or 

(ii) D = B + C where B and C are implication classes of E, and 4 + B 
+ Cis a multiplex of E of rank 2. 


Proof. Removing A from E may cause some implication classes of E to 
merge. Let D be the union of k implication classes of E. 

Assume k > 2; then there exists a triangle on vertices a, b, c with bee A 
and either ac € B and abe C or cae Band bae C, where B and C are distinct 
implication classes of E contained in D. Without loss of generality we may 
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assume ac € B and abe C since the other case is identical for D~!. Suppose 
B= C7', then ba, ace B. But bce¢ B, so by Theorem 5.4 B= B = B™', 
implying B = C, a contradiction. Therefore B 1 C = @ and Gra,b,c) 1S a 
tricolored triangle, making A + B + Ca multiplex of rank 2. 

Furthermore, any I’-chain in E — A containing edges from B and C could 
not contain edges from other implication classes since all triangles in E with 
one edge in A and a second edge in B (resp. C) must have its third side in C 
(resp. B) and would be isomorphic as a simplex to Gia,,c)- Thus k = 2 and 
D=B+C. 

Finally, we shall show that if k = 1, then A is an implication class of 
E — D. By what we have already proved, if A is not an implication class of 
E — D,then D + A + A, isa multiplex of rank 2 in E for some third implica- 
tion class A, of E. However, this implies that D alone is not an implication 
class of E — A, contradicting k = 1. So indeed A is an implication class of 
E —D. | 


Corollary 5.25. Let A be an implication class of an undirected G = 
(V, E). If A = A, then all other implication classes of E are again implication 
classes of E — A. 


Corollary 5.26. Let A be an implication class of an undirected graph 
G =(V, E). Then |.A(E)| = r + |.#(E — A)|, where r is the rank of the 
maximal multiplex of E containing A. 


The proof of the first corollary follows directly from Theorem 5.21, while 
the second corollary is a result of A being a part of exactly r — 1 different 
multiplexes of rank 2. | 


The next theorem is of major importance since it legitimizes the use of 
G-decompositions as a constructive tool for deciding whether an undirected 
graph is a comparability graph, and if so, producing a transitive orientation. 
Condition (iv) is the traditional characterization due to Gilmore and Hoffman 
(1964] and Ghouila-Houri [1962]. 


Theorem 5.27 (TRO Theorem). Let G = (V, E) be an undirected graph 
with G-decomposition E = B, + --- + B,. The following statements are 
equivalent: 


(i) G = (V, E)is a comparability graph; 
(ii) AOA} = @ for all implication classes A of E; 
(iii) BA By’ = @fori=1,...,k; 
(iv) every “circuit” of edges v,v2, v2.03, ..., ¥,0; € E such that v,_ 104, 
UqgV2, 0;- 10:41 ¢ E (for i = 2,...,q — 1) has even length. 
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Furthermore, when these conditions hold, B, + --- + B, is a transitive 
orientation of E. 


Proof. (i)= (ii) This is precisely Theorem 5.1. 


(ii) > (iit) We shall proceed by induction. Since B, is an implication 
class of E, we have B, 0 B;' = @. If k = 1, then we are done. Assume the 
implication is true for all G-decompositions of graphs of length less than k. 
Then, in particular, it is true for E — B,. 

Let D be an implication class of E — B,. By Theorem 5.24, either D is an 
implication class of E, in which case D1 D~! = @, or D = B + C, where B 
and C are implication classes of E such that B x C = @, implying that 


DoD! =(B+C)n(B'4+C 3) 
=(BOB™')+ (COC) 
=m, 


Therefore, by induction, B; 0 B; | = @, for i = 2,...,k. 

(iii) > (i) Let E = B, +---+ B, be a G-decomposition of E with 
B; 0 B; | = @. By Theorem 5.4, B, is transitive. If k = 1, then the implica- 
tion holds. Assume the implication is true for all G-decompositions of graphs 
of length less than k. By this assumption, F = B, + --- + B, is a transitive 
orientation of E — B,. We must show that B, + F is transitive. 

Let ab, bce B, + F. If both these edges are in B, or both in F, then by the 
individual transitivity of B, and F, ace B, + F. Assume, therefore, that 
ab € B, and bc € F, which implies that ab '* cb, so ac € E. What would happen 
ifac¢ B, + F? Then cae B, + F. However, 


caé B,, abe B, >cbeB,, a contradiction, 
and 


cae F, bce F > baeF, a contradiction. 


Thus ac € B, + F. Similarly, ab € F and bc € B, imply ace B, + F.So indeed 
B, +.---+ B, is a transitive orientation of E. 

(iv) (i) Suppose v,v,¢A AA ' # &. By Lemma 5.2, there exists a 
T-chain 


0,02 Tv30, Fv30, 0 --- Toe, Po ogvgs 1) = 0204. 


By construction, q is odd, since all first coordinates have odd index. Further- 
MOFEe, V,V2, V2V3,..., Vgv; iS Such a circuit, a contradiction. 
Conversely, if E has such a circuit of odd length q, then 


0,0, Tv30, TF v30,0---Pv,vj_, TP oj0, Tv. 0, 
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is a T-chain in E, implying that A A~! 4 @ for the implication class A 
containing v,v, a contradiction. | 


By combining the TRO theorem with the decomposition algorithm, we 
obtain an algorithm for recognizing comparability graphs and assigning a 
transitive orientation. 


Algorithm 5.2 (TRO Algorithm). 


Input: An undirected graph G = (V, E). 
Output: A transitive orientation F of edges of G, or a message that G is not a 
comparability graph. 
Method: The entire algorithm is as follows: 
begin 
Initialize: i — 1,2, —E;F-@; 
1. Arbitrarily pick an edge x,y; € E;; 


2. Enumerate the implication class B; of E; containing x;,y;; 
if B, 0 By! = & then 
add B; to F; 
else 
print *‘G is not a comparability graph”; 
STOP; 
3. Define: E;,, — E; — B;; 
4, if E;,, = @ then 
k < i; output F; 
STOP; 
else 
ieith; 
go to 1; 
end 


The sequence of free choices made in line 1 of the algorithm determines 
which of the many transitive orientations of G is produced by the algorithm. 
A different scheme may give a different transitive orientation. But when you 
try out a few different schemes you will notice a remarkable phenomenon: 
No matter how the free choices for G are made, the number of iterations k 
will always be the same. A proof that this is actually true for any graph G and, 
more importantly, a characterization of the underlying mathematical struc- 
ture which causes it are the subject of the next section. 


5. TheI*-Matroid of a Graph 


The Decomposition Algorithm 5.1 emphasizes that the order in which the 
edges appear in a scheme is extremely important. The free choices made in 


5. I*-Matroid of a Graph 125 


earlier iterations affect which edges remain to be chosen in latter iterations. 
If the algorithm once gave us a scheme [e,, €2, €3,.-., &,], what will happen if 
we rerun the algorithm by choosing e, first and e, second? Is there any reason 
for believing that e, will not have been removed and will therefore be available 
as the third free choice? The answer to the latter question is yes. 

All the results in this section are due to Golumbic [1977a]. 


Theorem 5.28. Let [e,, e2,..., ¢,] be a scheme for an undirected graph G, 
and let x be a permutation of the numbers {1,..., k}. Then [ej¢1), Cnc2y> «++ 
€n)] 18 also a scheme for G. 


Proof. If k = 1, then there is nothing to prove. Assume therefore that 
k > 2. Let B, + B, + --- + B, be the G-decomposition corresponding to the 
given scheme. Theorem 5.24 allows us to commute edges occurring next to 
each other in a scheme in the following manner. Fix i < k. Let 


E, = B,+---+ B, 
C; = implication class of E; containing e;, ,, 
C;41 = implication class of E; — C; containing e,. 


By Theorem 5.24, either (i) B;,, = C; and B; = C;,,, so that B; + B,,, = 
C; + C4 1, or (ii) there exists an implication class A of E; such that B.. = = 
A+C, and C,,, =4+ B,, also implying that B; + sa = C, 4+ Cray. 
Consequently, in either case, B, + --- + C, + Car +--+ B, is a G-de- 
composition of E with scheme [e,,..., @41, @,---5 &]- 

However, every permutation can be expressed as a composition of such 
local commutations (often called transpositions), from which the theorem 
follows. | 


Theorem 5.29 (Golumbic [1977a]). Let G = (V, E) be an undirected 
graph. 


(i) Each scheme for G has the same length. 
(ii}) Each G-decomposition of G has the same length. 
(iii) If[e,,e,,...,¢,] and [f,,f5,...,f,] are schemes for G, then for any 
e; there exists f; such that [e,,..., e—1,fj, @i41,+-+» &] is also a scheme for G. 


Proof. If G has an implication class A such that E = A, then any scheme 
has length 1 and any edge can be chosen as a scheme. Therefore, assume that 
the theorem is true for all graphs having fewer implication classes than G, and 
let [e,,e2,...,e,Jand[f,,fo,...,f,,] be schemes for G with k, m > 2. Choose 
e; and (using Theorem 5.28 if necessary) make sure that it is not in the first 
position. If E = C, + C, +--- + C,, is the G-decomposition corresponding 
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toLfi.fo,---fml, then e, eC, for some p. Thus [fy,.--.fp-1erSpt ++ Sul 
is also a scheme. Theorem 5.28 then implies that [e;,fi,.--.fp-ufp+1---oSml 
is a scheme for G. 

Finally, both [e., Savin Crp va Oe ANd: [Spee s fori dois eae Sek ate 
schemes for E — B, where B is the implication class of E containing e,. Since 
E — B has fewer implication classes than E, by induction the lengths k — 1 
and m — | are equal and there exists some f; which can replace e; in its scheme. 
In conclusion, since corresponding G-decompositions and schemes have the 
same length, all G-decompositions must have the same length. | 


Thus we have found a number associated with an undirected graph G 
which is invariant over all schemes and G-decompositions of the graph, 
namely the length of any scheme or G-decomposition of G. We shall denote 
this number by r(G). 


Theorem 5.30. Let G =(V, E) be an undirected graph, and let E = 
M,+---+M,, where M; is a maximal multiplex of E of rank r;. Then 
(G) =r, +---+%. 


Proof. Let Ae€.4(G) satisfy A < M,. Now M, — A is a multiplex of 
rank r, — 1, and E— A =(M, — A,) + M, +---+ M, is an M-decom- 
position of G’ = (V, E — A). Since |.4(G)| > |.4(G’)|, we may assume by 
induction that r(G’))=(r, - 1) +7. +---+7r,. Therefore, r(G) =r, + 
ro +--+ + Py. 


Let G =(V, E) be a comparability graph with G-decomposition E = 
B, +--- + B, and corresponding scheme [e,, ..., e]. By Theorem 5.27, 
B, +--+ + B, will be a transitive orientation of G. Replacing e; by e; ‘ in the 
scheme will have the effect of replacing B; by B; ‘, thus giving a new transitive 
orientation of G. In this manner we obtain 2’ transitive orientations of G, 
since k = r(G). There may, however, be others; the scheme [e,(1),---, €xa] 
may even give a transitive orientation of G different from the 2” above. In 
fact, the only time when these 2” represent all the transitive orientations of 
Gis when each maximal multiplex is of rank one. (This follows from Theorems 
5.22 and 5.30 and the inequality 2’ < (r + 1)! for r > 1.) For example, 
r(K,+1) = rand t(K,,,) = (r + 1)! for the complete graph onr + 1 vertices. 
On the other hand, the graph G in Figure 5.9 has «(G) = 2’. 


Story 


The owner of a large railroad decided to introduce his sons into the 
business. He asked his eldest to choose any two cities between which they 
provide train service, and the father would give him control of that run. The 
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Figure 5.9. The number of triangles is r(G) — 1. 


lad chose New York and Philadelphia. But the boy was clever and reasoned 
with his father saying, “Since you operate service between Harrisburg and 
Philadelphia and I operate the New York-—Philadelphia trains, and since we 
don’t offer any direct service between Harrisburg and New York, why not 
give me also the Harrisburg-Philadelphia run for the convenience of our 
passengers who would otherwise be burdened with their heavy luggage in 
changing trains!” 

The father was convinced by the son’s argument and gave him the extra 
rail link. The son, encouraged by his success, continued this type of reasoning 
for triples of cities that fit the above pattern and accumulated more rail lines 
until finally no more triples of that form were left. His father handed him the 
corresponding deeds; they embraced and the son left to go out on his own. 

The father continued the same process with his other sons, giving one 
rail line and then also giving any other link A—B when the son already con- 
trolled B—C provided they did not operate A-C between the two of them. 
Finally, the father had given away his entire rail system. 

Theorem 5.29 shows that no matter how each son chooses his initial free 
choice, exactly r(G) sons get portions of the railroad, where G is the graph 
whose vertices are the cities and edges the rail links. 


We will now describe the underlying mathematical structure that causes 
the invariant r(G) to arise. 

A matroid <E, @) consists of a nonempty (finite) set E of elements together 
with a nonempty collection Y of subsets of E, called bases, satisfying the 
following axioms. 


(i) No base properly contains another base. 
(ii) Iff,, B,¢4 and xe f,, then there exists an element ye 8, such that 


(Bi — {x} + eB. 


Theorem 5.31. Let G = (V, E) be an undirected graph. 


(i) <E, @> isa matroid, where {e,,..., e,} «eB if and only if [e,,..., e,] 
is a scheme for G. 
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(ii) . Cu (G), &(G)) is a matroid, where .A(G) is the set of color classes of G 
and {A,,..., A,} € A(G) if and only if {e,,..., e,} eB for e; € A;. 


Proof. The order in which the edges appear in a scheme is important for 
the G-decomposition it will produce. Theorem 5.28, however, allows us to 
treat schemes as sets of chosen representative edges in which order is not 
relevant. By Theorem 5.29, these subsets satisfy the axioms of a matroid. This 
proves (i). Condition (ii) follows easily from (i). | 


The matroid ¢.¥/G), B(G)) may be regarded as the quotient of the matroid 
<E, @>. For those readers familiar with matroids, the invariant r(G) equals the 
rank (in the usual matroid sense) of <E, @> and of <.A(G), B(G)>. These 
matroids are of a very special type. Let us see exactly what class of matroids 
is produced in this manner. 

By Theorem 5.24, the free choices taken from one maximal multiplex in no 
way influence choices taken from any other maximal multiplex. Therefore, it 
suffices to restrict our attention to applying the decomposition algorithm 
to a maximal simplex (Vj, S). Let r = rank S. Its free choices (r of them) 
constitute the edges of a spanning tree of (Vs, S$). Why is that? It is certainly 
true ifr = | orr = 2. If it were false, then there would be a scheme f contain- 
ing a simple cycle of edges v,v,, v.03, ..., vv, of minimal length / over all 
schemes. By Theorem 5.24, | # 3. Again by Theorem 5.24, vv, could be 
replaced by v,0, in f, forming another scheme with a cycle of length less than 
I, contradicting minimality. Therefore, the r edges contain no simple cycles 
and must be a spanning tree of (Vg, S), since there are r edges and r + 1 
vertices. Furthermore, any spanning tree of (Vs, S) is a scheme since it contains 
r edges, and for every other edge ab the tree provides a path e,,e,,...,e, from 
a to b which, when used successively in the construction of a G-decom- 
position, will also eliminate the edge ab. 

Two matroids <E,, @,> and <E,, #,» are isomorphic if there exists a 
bijection f: E, + E, such that 


SBE forall B, ER, 


and 
f \(B,6€B, forall p,¢B). 
Let .@ denote the family of matroids 
M = {<.K(G), B(G)> |G is an undirected graph}. 


From the above discussion we may state the following characterization of 
the matroids in .@. 


6. Complexity of Comparability Graph Recognition 129 


Theorem 5.32. A matroid is in the family .@ if and only if it is isomorphic 
to the matroid of spanning trees of a set of disjoint complete graphs. 


6. The Complexity of Comparability Graph Recognition 


A version of the decomposition algorithms of Section 5.4 is presented here 
in a pseudo-computer-language. It will suggest to us how we may actually 
enumerate the implication classes of a graph. We shall show that one can 
find a G-decomposition and test for transitive orientability of an undirected 
graph G = (V, E) in O(6-|E|) time and O(|V| + |E|) space, where 6 is the 
maximum degree of a vertex. 

Let G = (V, E) be an undirected graph with vertices v1, v2,..., v,. In the 
algorithm below we use the function 


0 : if v; 0; ¢ E, 
CLASS(i, j) = k if v;v; has been assigned to B,, 
~k if v;v; has been assigned to B, ', 


undefined if v,v; € E has not yet been assigned, 


and | CLASS(, j)| denotes the absolute value of CLASS(i, j). As usual, the set 
E is always assumed to be a collection of ordered pairs and the degree d; of 
vertex v; is taken here to mean the number of edges with »; as first coordinate 
(i.e., the out-degree). We freely use the identity , 


n 
|E| = > d; 
i=1 
in our analysis. 


Algorithm 5.3 (Decomposition Algorithm—Alternate Version). 


Input: An undirected graph G = (V, E) with vertices v,, v2, ..., v, whose 
adjacency sets obey j € Adj(i) if and only if v;v,€ E. 

Output: A G decomposition of the graph given by the final values of CLASS 
and a variable FLAG which is 0 if the graph is a comparability graph and 1 
otherwise. If the algorithm terminates with FLAG equal to zero, then a transi- 
tive orientation of G is obtained by combining all edges having positive 
CLASS. 

Method: The algorithm proceeds until all edges have been explored. In the 
kth iteration an unexplored edge is placed in B,. (Its CLASS is changed to 
k.) Whenever an edge is placed into B, it is explored using the recursive 
procedure of Figure 5.10 by adding to B, those edges IT-related to it in the 
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procedure EXPLORE(. /): 
for each m € Adj(i) such that [m ¢ Adj(/)or |CLASS (/, m) | <k] do 
begin 
if CLASS (i, m) is undefined then 
begin 
CLASS(i, m) — k; CLASS(m, i) — —k; 
EXPLORE(i, m); 
end 
else 
if CLASS(i, m) = —k then 
begin 
CLASS(i, m) — k; FLAG <— 1; 
EXPLORE(i, m); 
end 
end 
for each m € Adj(/) such that [m: ¢ Adj(i) or |CLASS(i, m)| <k] do 
begin 
if CLASS(m, /) is undefined then 
begin 
CLASS(m, j) — k; CLASS(j,m) — —k; 
EXPLORE(™, j); 
end 
else 
if CLASS(m, j) = —k then 
begin 
CLASS(m, /) — k; FLAG + 1; 
EXPLORE(™, /); 
end 
end 
return 


Figure 5.10. 


graph E,. (Notice that v,v; € E, ifand only if either | CLASS(i, j)| equals k or is 
undefined throughout the kth iteration.) 

The variable FLAG is changed from 0 to | the first time a B, is found such 
that B, 0 B, | # @. At that point it is known that G is not a comparability 
graph (by Theorem 5.27). 

The algorithm is as follows: 
begin 

initialize: k — 0; FLAG < 0; 

for each edge u,v; in E do 

if CLASS (i, /) is undefined then 
begin 
ke-k +1; 
CLASS (i, /) — k; CLASS (j,i) — —k; 
EXPLORE (i, /); 
end 
end 
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We begin by specifying an appropriate data structure. The adjacency sets 
are stored as linked lists sorted into increasing order. The element of the list 
Adj(i) which represents edge v;v; will have four fields containing j, CLASS(i, /), 
pointer to CLASS(j, i), and pointer to next element on Adj(i) (see Figure 
5.11). The storage requirement for this data structure is O(|V| + |£]), and if 
sorting the lists is done using Algorithm 2.1, then the entire initialization of 
the data structure can be accomplished in linear time. 

The crucial factor in the analysis of our algorithm is the time required to 
access or assign the CLASS function. Ordinarily finding CLASS(i, m) could 
take O(d;) steps by scanning Adj(i), but if a temporary pointer happened to 
be in the neighborhood, then a reference to CLASS(i, m) or CLASS(m, i) 
would take a fixed number of steps. Consider the first loop of EXPLORE, j). 
Two temporary pointers simultaneously scan Adj(i) and Adj(j) looking for 
values of m which satisfy the condition in the for statement. Since the lists are 
sorted and thanks to these neighborly pointers, this loop can be executed in 
O(d; + d;) steps. The second loop is done similarly ; hence the time complexity 
of EXPLORE(i, j) is O(d; + d,). 


Figure 5.11. An undirected graph, the transitive orientation generated by the scheme 
{(, 2), (4, 3)] and its data structure after running the algorithm. 
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In the main program, a temporary pointer scans each adjacency list 
successively in the for loop, implying a time complexity of O(| E|). Finally, the 
algorithm calls EXPLORE once for each edge or its reversal (both if their 
implication classes are not disjoint). Therefore, since 


YG + 4) =2¥ d? < 26Y d,; = 26|E|, 
vivjeE i=1 i=1 

it follows that the time complexity for the entire algorithm (including pre- 
processing the input) is at most O(6 - | E|). Thus we have proved the following: 


Theorem 5.33. Comparability graph recognition and finding a transitive 
orientation can be done in O(6-|E|) time and O(|V| + |E|) space, where 6 
is the maximum degree of a vertex. 


The algorithm as presented in this section explores the edges in a depth-first 
search. Replacing each recursive call EXPLORE(x, y) by placing xy in a 
queue of edges to be explored would change the algorithm to breadth-first 
search. Some future application may lead us to prefer one over the other. 


7. Coloring and Other Problems on Comparability Graphs 


To any acyclic orientation F (not necessarily transitive) of an undirected 
graph G = (V, E) we may associate a strict partial ordering of the vertices, 
namely, x > y iff there exists a nontrivial path in F from x to y. A height 
function h can then be placed on V as follows: h(v) = Oif visa sink; otherwise, 
h(v) = 1 + max{h(w)|vw € F}. We have already seen, in Chapter 2, Exercise 
8, that the height function can be assigned in linear time using a recursive 
depth-first search. The function h is always a proper vertex coloring of G, 
but it is not necessarily a minimum coloring. The number of colors used will 
be equal to the number of vertices in the longest path of F. This is also equal 
to 1 + max{h(v)|v € V} since we started at height (color) zero. A poor choice 
of F may result in an overly colorful coloring. However, the situation is 
guaranteed to be better if F happens also to be transitive. 

Suppose that G is a comparability graph, and let F be a transitive orienta- 
tion of G. In such a case, every path in F corresponds to a clique of G because 
of transitivity. Thus, the height function will yield a coloring which uses 
exactly w(G) colors, which is the best possible. Moreover, since being a 
comparability graph is a hereditary property, we find that w(G,4) = x(G,4) for 
all induced subgraphs G, of G. This proves the following result. 
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Theorem 5.34. Every comparability graph is a perfect graph. 


Theorem 5.34 coupled with the Perfect Graph Theorem 3.3 implies that the 
stability number of a comparability graph is equal to the clique cover number 
of the graph. This proves the following classical result. 


Theorem 5.35 (Dilworth [1950]). Let (X, <) be a partially ordered set. 
The minimum number of linearly ordered subsets (usually called chains) 
needed to partition X is equal to the maximum cardinality of a subset of X 
having no two members comparable (usually called an antichain). 


Many proofs of Dilworth’s theorem can be found in the literature. Among 
them, those of Fulkerson [1956] and Perles [1963] seem most elegant. The 
reader is referred also to Dilworth [1950], Pretzel [1979], Trotter [1975], and 
Tverberg [1967]. Greene and Kleitman [1976] have recently extended 
Dilworth’s theorem to more general partitions of a poset into chains. Some 
related references include Greene [1974, 1976], Griggs [1979], and Hoffman 
and Schwartz [1977]. 

We direct our attention next to some algorithmic aspects of problems on 
comparability graphs. In Section 5.6 we showed that a transitive orientation 
F could be constructed for a comparability graph G in O(d6e + n) steps, where 
6 is the maximum degree of a vertex, e is the number of edges, and n is the 
number of vertices. From the transitive orientation F we can assign a mini- 
mum coloring of G using the height function in O(n + e) additional steps. 
At the same time a maximum clique could also be calculated. We shall il- 
lustrate this by solving a slightly more general problem. 


MAXIMUM WEIGHTED CLIQUE. 

Instance: An undirected graph G and an assignment of a weight w(v) to each 
vertex v. 

Question: Find a clique of G for which the sum of the weights of its vertices is 
largest possible. 


If all vertices have the same weight, then the problem is reduced to the 
usual problem of finding a clique of maximum cardinality. In general the 
MAXIMUM WEIGHTED CLIQUE problem is NP-complete, but when 
restricted to comparability graphs it becomes tractable. 


Algorithm 5.4. Maximum weighted clique of a comparability graph. 
Input: A transitive orientation F of a comparability graph G = (V, E) and 
a weight function w defined on V. 

Output: A clique K of G whose weight is maximum. 
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procedure EXPLORE(r): 
if Adj(v) = @ then 
Ww) = wv); 
POINTER(v) < A; 
return; ; 
for all x e Adj(v) do 
if x is unexplored then 
EXPLORE(x); 
end for all; 
select y € Adj(v) such that W(y) = max{W(x) |x € Adj(v)}; 
W(v) — wv) + WO); 
POINTER(v) < y; 
return 
end 


Figure 5.12. 


Method: We use a modification of the height calculation technique employing 
the recursive depth-first search procedure EXPLORE in Figure 5.12. To 
each vertex v we associate its cumulative weight W(v), which equals the 
weight of the heaviest path from v to some sink. A pointer is assigned to v 
designating its successor on that heaviest path. Lines 4-10 calculate K once 
the cumulative weights are assigned. The algorithm is given as a procedure. 


procedure MAXWEIGHT CLIQUE(V. F): 
1. for allue Vdo 


2. if v is unexplored then 
3. EXPLORE (v); 
end for all; 


4, select y ce V such that W(y) = max{W(v) |v € VY}; 
5. Ke {y}; 

6. y < POINTER (y); 

7. while y # Ado 

8 K+ K vu {y}; 

9. y — POINTER ());; 

0. return K; 

end 


Proving the correctness of Algorithm 5.4 and displaying an implementation 
whose complexity is linear in the size of the graph (assuming that F is provided 
to the algorithm in the proper data structure) are left as exercises for the 
reader. 

We conclude with an interesting polynomial-time method for finding 
a(G), the size of the largest stable set of a comparability graph G. We trans- 
form a transitive orientation (V, F) of G into a transportation network by 
adding two new vertices s and t and edges sx and yt for each source x and 
sink y of F. Assigning a lower capacity of 1 to each vertex, we initialize a 
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compatible integer-valued flow and then call a minimum-fiow algorithm. 
The value of the minimum flow will equal the size of the smallest covering of 
the vertices by cliques, which in turn will equal the size of the largest inde- 
pendent set since every comparability graph is perfect. Such a minimum- 
flow algorithm can run in polynomial time. (See Figure 2.1 for the complex- 
ities of various maximum-flow algorithms.) 


8. The Dimension of Partial Orders 


Szpilrajn [1930] first noted that any partial order (X, P) could always be 
extended to a linear ordering L of X. In Section 2.4 we called such a linear 
extension a topological sorting. Let Y(P) denote the collection of all linear 
extensions of P. Any subset Y © ¥(P) satisfying (\,.¢ L = P is called a 
realizer of P, and its size is |¥&|. The intersection is that of sets of ordered 
pairs, that is, 

abe ()L<abeL  forevery LeJY. 
LeL 

Clearly, f(P) itself is a realizer of P. We define the dimension of P, dim P, 
to be the size of the smallest possible realizer for P. Such a realizer is called a 
minimum realizer for P. The notion of dimension of a partial order first 
appeared in Dushnik and Miller [1941]. 


Examples. The partial order P whose Hasse diagram is illustrated in 
Figure 5.13 has dimension 2. A minimum realizer for P is also shown. Notice 
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Figure 5.13. A partial order P of dimension 2. We have P = L; nN L2. 
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Figure 5.14. A partial order P of dimension 3. We have P = L, 4 L, 0 L3. Why would 
two linear orders be insufficient to realize P? 


that the subposet P’ which is circled also has dimension 2 and that it must 
appear above element a in one of the linear orders and below element a in 
the other. Figure 5.14 shows the Hasse diagram of a partial order whose 
dimension is 3 (see Exercise 16). 


Lemma 5.36. Let (X, P) be a poset. For each Y € X, we have 
dim Py < dim P. 


Proof. Clearly, restricting the linear extensions in a realizer ¥ of P to the 
elements of Y yields a realizer (not necessarily minimum) of Py. Choosing # 
to be minimum for P we obtain the result. | 


Theorem 5.37 (Hiraguchi [1951]). Let P = P,[P,, P,,...,P,] be the 
composition of disjoint partial orders (X;, P;) (0 < i < k). Then 


dim P = max{dim P;|0 <i < k}. 


Proof. For each i, let L;;, Li2,..., Lj,_ be a realizer for P;, where 
m = max{dim P;|i = 0, 1,..., k}. Define 


A; as Lo, [L1,;, L, tees L,,;]- 


Then {A,|j = 1, 2,..., m} is a realizer of P, so dim P < m. 

Next, observe that P contains each of the P; as a subposet. (To obtain Py 
take a set of representatives from X,, ..., X;,.) Hence, by Lemma 5.36, 
m < dim P. I 


As noted earlier, the dimension of a partial order was introduced by Dush- 
nik and Miller [1941]. They showed that there exist partial orders of dimen- 
sion d for all positive integers d, and they gave the first characterization of the 
posets of dimension 2. We shall briefly mention some other known results on 
dimension theory. A special bibliography on the subject appears at the end of 
this chapter. In addition, W. T. Trotter is currently completing a book on the 
subject. 
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Figure 5.15. The Hasse diagram of the crown B}. 


Let S be a nonempty set and let A(S) denote its power set ordered by inclu- 
sion. Komm [1948] proved that dim A(S) = |S|. Hiraguchi [1951] showed 
that dim P < 4|X| for any partial order (X, P) and gave examples of posets 
for which equality holds. Another proof of this result can be found in Bogart 
[1973]. 

Sedmak [1952-1954] investigated the poset P(x) consisting of the empty 
set and the points, lines, faces, etc., of a polyhedron x in R*. He proved the 
following implications. 


(1) If isa polygon in R?, then dim P(x) = 3. 

(2) If zis a polyhedron in R°, then dim P(x) > 4, with equality holding 
for regular polyhedra, pyramids, prisms, and their duals in R°. 

(3) There exist polyhedra in R? with arbitrarily high dimension. 


This problem was originally posed by Kurepa [1951]. 

Ducamp [1967] showed that finding a minimum realizer for a partial order 
is equivalent to a certain bipartite covering problem. However, for all but 
small posets the method is intractable. 

Let G be a connected undirected graph, and let P(G) denote the collection 
of connected induced subgraphs of G ordered by inclusion. Trotter and Moore 
[1976a] proved that dim P(G) equals the number of nonarticulation vertices 
of G. (A nonarticulation vertex is one whose removal from G leaves it con- 
nected.) This result generalizes a result of Leclerc [1976], namely, the dimen- 
sion of the collection of subtrees of a tree T ordered by inclusion equals the 
number of leaves of T. The special case of dim P(G) = 2 was done by Dushnik 
and Miller [1941]. 

Trotter [1974a] studied the class of partial orders called crowns, obtaining 
an exact formula for their dimension. Briefly, let B), be a poset on 2m elements 
split into an incomparable set {xo, X;,..-., X»,— ,} and another incomparable 
set {yo. Vis +++, Vm—1} With x;y,¢ By, forj =i+ 1,i+ 2,...,i+ 1 (addition 
modulo m) (see Figure 5.15). Trotter proved that for 0 < 1 < mand m > 3 


dim B!, = [2m/(m — 1+ 1)]. 
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Baker, Fishburn, and Roberts [1972] used the family {B2},,, 3 to show that, 
for any n > I, the collection of all posets of dimension <n is not axiomatiz- 
able by a sentence in first-order logic and cannot be characterized by a finite 
collection of forbidden subconfigurations. 

Ore [1962] observed that the dimension of a partial order could be viewed 
in another, equivalent manner. The points in the Euclidean space R* of 
dimension k can be partially ordered in a natural way: (x;, x2, ..., %) < 
(V1, Yao -++5 Ve) iff x; < y; for each i. Then the dimension of a poset P is the 
smallest nonnegative integer k for which P can be embedded in R*. In some 
sense this justifies the choice of the term dimension for partial orders. 

Rabinovitch [1973, 1978a] has shown that the dimension of a semiorder 
is at most three. Semiorders arise naturally in psychology* and are discussed 
in Chapter 8. Kelly [1977] and Trotter and Moore [1976b] have character- 
ized all posets of dimension 3. 


Application. Let (XY, P) bea partially ordered set, perhaps obtained as the 
transitive closure of an acyclic graph, and let |X| = n. The dim P may be 
regarded as the minimum number k of attributes needed to distinguish be- 
tween the comparability and incomparability of pairs from X. The technique 
is the following: To each item x € X we associate a k-tuple (x,, X2,..., X,) 
e R*, where x; is the relative position of x in L; and Y = {L;} is a minimum 
realizer of P. In such a setup, (X, P) would be stored using O(kn) storage 
locations, and a query of the form “Is xy e¢ P?” will require at most k com- 
parisons. This technique is advantageous when n is large and k is very small 
provided that the preprocessing needed to obtain a minimum realizer is not 
too expensive. This is always the case when dim P < 2. 


Theorem 5.38 (Dushnik and Miller [1941]). Let G be the comparability 
graph of a poset P. Then dim P < 2 if and only if the complementary graph 
G is transitively orientable. 


Proof. Let F be a transitive orientation of G. It is easy to show that 
Lf ={P4+F,P + F7'}isarealizer of P. Conversely, if Y = {L,, L,} is any 
realizer of P, then F = L, — P = (L, — P)7' is a transitive orientation of 
G. For, suppose ab, bc € F but ac ¢ F. The transitivity of L, implies that ac € P; 
similarly, the transitivity of L, implies that cae P, a contradiction. | 


* Some psychologists believe that preference is based on a single criterion with some degree 
of fuzziness; this viewpoint is modeled in Section 8.5. Other psychologists believe that the brain 
is actually comparing multiple criteria; this viewpoint is modeled by the realizers described in 
this section. 


+, To date the complexity of computing dim P for an arbitrary poset P is unknown. It may or 
may not be NP-complete. 
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From the preceding theorem it follows that two partial orders which have 
the same comparability graph either both have dimension <2 or both have 
dimension > 2. A stronger result holds, which we shall now present. 


Theorem 5.39 (Trotter, Moore, and Sumner [1976]). If two partial 
orders P and Q have the same comparability graph G, then dim P = dim Q. 


Proof. The theorem is certainly true for posets of one element. We 
proceed by induction. Let (X, P) and (X, Q) be partial orders having the same 
comparability graph G, and let us assume that for all proper subsets Y of X, 
dim Qy = dim Py. There are two cases to consider. 


Case 1: G is indecomposable. In this case, Corollary 5.13 implies that G is 
UPO. Therefore, either P = Q or P = Q™', both implying that dim P = 
dim Q. 

Case 2: G is decomposable. Let G = Gp[Gy,, ..., Gy,] be a proper de- 
composition of G. By Corollary 5.7, P = Pr[Py,,..., Py,] and QO = 
OrlQy,,.--, Qv,]. Applying Theorem 5.37 and the induction hypothesis, 
we can obtain 

dim P = max{dim Pr, dim Py,,..., dim Py,} 
= max{dim Qe, dim Q,,,..., dim Qy,} 
= dim Q | 

Theorem 5.39 also appears in Gysin [1977]. 

In a personal communication, Richard Stanley has reported that two 
partial orders P and Q having the same comparability graph also have the 


same number of linear extensions, i.e., | f(P)| = | 4(Q)|. His proof is based 
on the results of Section 5.3. 


EXERCISES 


1. G) Prove that the forcing relation * is an equivalence relation. 
(ii) Prove that the following properties hold: 
abT a'b’<=baT ba’ 
ab 1* a'b' = ba T* b’a’ 
2. The complete graph K, has two implication classes. Give a formula for 
|.£(K,,)| for n > 2. 


3. Which of the graphs in Figure 5.16 are comparability graphs? How many 
implication classes and color classes do they have? 
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RIANA 


Figure 5.16. 


4. Let G bea connected comparability graph whose complement G is con- 
nected and contains no induced subgraph isomorphic to K,,. Prove that 
G is UPO. [Hint: Use Theorem 5.12 (Aigner and Prins [1971]).] 

5. Prove the following result for an undirected graph G. If F, and F, are 
transitive orientations of G and G, respectively, then F, + F, is a transitive 
tournament. 

6. Draw the graph G = H,[H,, H,, H;, H,] for the graphs in Figure 5.17. 
Verify that it has 16 color classes: 9 within the internal factors, 6 among the 
external edges connecting H, with H,, and 1 consisting of the remaining 
external edges. Prove that G has 1440 transitive orientations. 


Yakhvy 


Figure 5.17. 


7. Show that ifan undirected graph G has no induced subgraph isomorphic 
to the path P,, then both G and G are comparability graphs. 

8. Verify that the graph in Figure 5.18 has four color classes partitioned 
into two maximal multiplexes of rank 1 and 2, respectively. Use the decompo- 
sition algorithm of Section 5.4 to obtain a G-decomposition of this graph. 
(One solution is given in Appendix D.) Is this graph a comparability graph? 


Figure 5.18. 


9. Calculate r(G) for the graphs in Exercises 3, 6, and 8. 
10. Let a(G) be the stability number of an undirected graph G = (JV, E). 
Prove that r(G) < |V| — «(G) (Golumbic [1977a]). 
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11. A binary relation R is vacuously transitive if R* = @. (Vacuously 
transitive relations have been studied by Sharp [1973].) Prove that an un- 
directed graph has a vacuously transitive orientation if and only if it is 
bipartite. 

12. Prove that every transitive orientation of a comparability graph G is 
obtainable from some G-decomposition of G. 

13. Let G = (V, E) be an undirected graph, and consider the equivalence 
relation ~, defined on V as follows: 


a~a iff Adj(a) = Adj(a’). 


By irreflexivity, equivalent vertices are not adjacent. We form the quotient 
graph G = (V, E) by merging equivalent vertices. Formally, let V be the set 
of all equivalence classes under ~, and let @ denote the ~-class containing 
the vertex a. For any subset of edges A ¢ E we define 


A = {ab|abe A}. 


(i) Prove that abe E <> abe E. Give an example of a graph G and a 
subset of edges A such that cde A but éd ¢ A for some edge cd. 

Gi) Prove that the following conditions are equivalent: 

(1) ab = éd, 
(2) a~candb~d, 
(3) @=éand6 =d. 

(iii) Prove that (1)-(3) above imply that abI’* cd but not conversely 
(Golumbic [1977b]). 

14. Let G = (V,E) bean undirected graph and let G = (V, E) be its quotient 
graph as defined in Exercise 13. Prove the following. 

(i) If Ae.4(G), then Ae .4(G). 

(ii) If[e,,e,...,e,] is a scheme for G with corresponding G decomposi- 
tion B, + B, + --- + B,, then [é,, @,..., &] is a scheme for E with cor- 
responding G-decomposition B, + B, +--- + B,. 

(iii) If (V, F) is a transitive orientation of G, then (V, F) is a transitive 
orientation of G. 

(iv) Every implication class, scheme, G-decomposition, and transitive 
orientation of G is of the form indicated in (i)-(iii) (Golumbic [1977b]). 

15. Prove that Algorithm 5.4 correctly computes a maximum weighted 
clique of a comparability graph. Show that the algorithm can be implemented 
to run in linear time in the size of the graph. 

16. Prove that the partial order in Figure 5.14 has dimension 3. 

17. Let Q bea subset of R‘, and for 1 < i < k let Q; consist of those numbers 
which appear as the ith coordinate in some k-tuple in Q. Consider the natural 
partial order on Q as defined in Section 8. 
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Gi) Show that if Q is the Cartesian product Q = Q, x Q, x --- x Q, and 
|Q;| = 2 for each i, then dim QO = k. 

(ii) Prove Komm’s theorem, namely, that dim A(S) = k for a set S. 
18. Complete the proof of Theorem 5.38. 
19. A partial order (X, P) is an interval inclusion order if X can be put into 
one-to-one correspondence with a family {J,}...x of intervals on a linearly 
ordered set such that 


x<y ifff, cl, (Vx, ye X). 


Prove the following: dim P < 2 if and only if P is an interval inclusion order 
(Dushnik and Miller [1941]). 
20. Let G = (V, E) be an undirected graph. Show the following statements 
are equivalent: 
(i) Ghasa transitive orientation whose Hasse diagram is a rooted tree; 

(iit) Gis acomparability graph and the Hasse diagram of every transitive 
orientation of G is a rooted tree; 

iii) if a, b, c, de V are distinct vertices satisfying ab, bc, cde E, then 
either ace E or bde E; 

(iv) G contains no induced subgraph isomorphic to C4 or P,. 
Give an example of a comparability graph which is triangulated and whose 
complement is a comparability graph but which fails to satisfy the conditions 
above (Wolk [1962, 1965]). Arditti [1975b] has investigated comparability 
graphs whose Hasse diagram is a tree. 
21. Show that the leaves of a rooted tree can be linearly ordered so that the 
set of decendent leaves of any vertex occur consecutively. Use this result to 
show that any graph G which is the comparability graph of a rooted tree is 
also an interval graph. 
22. If B, + B, +---+ B, is a G-decomposition of an undirected graph 
G = (V, E), then B, + --- + B,is called a partial G-decomposition for each 
j =0, 1,..., k. Show that the subgraphs of G obtained as partial G-de- 
compositions (including @ and E) form a lattice. Show that this lattice is 
modular but not necessarily distributive. 
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CHAPTER 6 


Split Graphs 


1. An Introduction to Chapters 6-8: 
Interval, Permutation, and Split Graphs 


An undirected graph G may possess one or more of these familiar proper- 
ties: 


Property C: Gis a comparability graph. 

Property C: G is a comparability graph (i.e., G is a cocomparability graph). 
Property T: G is a triangulated graph. 

Property T: G is a triangulated graph (i.e., G is a cotriangulated graph). 


These four properties are independent of one another. Examples of all 
16 possible combinations are given in Appendix F. 

Chapters 6-8 deal with the classes of graphs which have been characterized 
in terms of these four properties. In particular, we shall show the following: 


interval graphs = T + C; 
permutation graphs = C + C; 
split graphs = T + T. 


We begin our study with split graphs, which are defined in the next section. 
Chapters 6-8 are independent of one another; they may be read in any order 
without loss of continuity. 


2. Characterizing Split Graphs 


An undirected graph G = (V, E) is defined to be split if there is a partition 
V=S + K of its vertex set into a stable set S and a complete set K. There is 
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Figure 6.1. A split graph with one of its four partitions indicated. The other partitions are 
(S — {x;}) + (K vu {x;}) for i= 1,2,3. 


no restriction on edges between vertices of S and vertices of K. In general, 
the partition V = S + K of a split graph will not be unique; neither will S 
(resp. K) necessarily be a maximal stable set (resp. clique). For example, the 
graph G in Figure 6.1 has four partitions, one of which is indicated. Notice 
also that |S| = a(G) = 4 whereas 4 = |K| < w(G) = 5; S is the only maxi- 
mum stable set of G, and K u {x,} (for i = 1, 2, 3) are the only maximum 
cliques. 

Since a stable set of G is a complete set of the complement G and vice versa, 
we have an immediate result. 


Theorem 6.1. An undirected graph G is a split graph if and only if its 
complement G is a split graph. 


The next theorem follows from the work of Hammer and Simeone [1977]. 


Theorem 6.2. Let G bea split graph whose vertices have been partitioned 
into a stable set S and a complete set K. Exactly one of the following con- 
ditions holds: 


(i) |S|=a(G) and |K| = a(G) 

(in this case the partition S + K is unique), 
(ii) |S} =a(G) and |K| = a(G)—1 

(in this case there exists an x € S such that K + {x} is complete), 
Git) [S| =oa(G)-—1 and |K| = a@(G) 

(in this case there exists a ye K such that S + {y} is stable). 
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Proof. Since a stable set and a complete set can have at most one common 
vertex, it follows that a split graph has the sum a(G) + @(G) equal to either 
\Vior|V] +1. 

If a(G) + w(G) = |V], then we are in case (i). Suppose, in this case, there 
is another partition V = S’ + K’. Let {x} = So K' and {y} = S’n kK. If x 
and y are adjacent in G, then {x} + K is a clique of size w(G) + 1, which is 
impossible. If x and y are not adjacent in G, then {y} + S is a stable set of 
size o(G) + 1, which is impossible. Hence, the partition V = S + K must be 
unique. 

If o(G) + w(G) = |V]| + 1, then we are in either case (ii) or case (ii). We 
will prove the claim in case (ii) only, case (iii) being analogous. Let |S| = «(G), 
|K| = w(G) — 1 and let K’ bea clique of size w(G). Since S + K isa partition 
and K’ is larger than K, S q K’ must be nonempty and therefore of cardinality 
1. Let {x} = S71 K’, it follows that K’ = K + {x}, which is complete. | 


Theorem6.3 (Féldes and Hammer [1977b]). Let G be an undirected 
graph. The following conditions are equivalent: 


(i) Gis a split graph, 
(ii) Gand G are triangulated graphs, 
(iii) G contains no induced subgraph isomorphic to 2K,, C4, or Cs. 


Proof. (i) = (ii) Let G = (V, E) have vertex partition V = S + K with 
S stable and K complete. Suppose G contained a chordless cycle C of length 
>4. At least one and at most two (adjacent) vertices of C would be in K. 
Both cases would imply that S$ contains a pair of adjacent vertices, a contra- 
diction. Therefore, G must be triangulated. By Theorem 6.1, G is split, so G is 
triangulated. 

Gi) > (iii) Immediate. 

(ili) => (@) Let K be a maximum clique of G chosen (among all maximum 
cliques) so that Gy_x has fewest possible edges. We must show that S = 
V — K is stable. 

Suppose, on the contrary, that Gs has an edge xy. By the maximality of K, 
no vertex of S could be adjacent to every member of K. Moreover, if both 
x and y were adjacent to every vertex of K with the exception of the same 
single vertex z, then K — {z} + {x} + {y} would be a complete set larger 
than K. Thus, there must exist distinct vertices u, v¢ K such that xu ¢ E and 
yo€ E. 

Since G contains neither an induced copy of 2K, nor C4, it follows that 
exactly one of the edges xv or yu is in G. Assume, without loss of generality, 
that xv¢ E and yue E. For any we K — {u,v}, if ypwé E and xw€ E, then 
Gx, y,0,w) & 2K2, whereas if yw¢ E and xwe E, then G;, yyw, = C4. Thus, 
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y is adjacent to every vertex of K — {v}, and K’ = K — {v} + {y} is a 
maximal clique. 

Since Gy _x can have no fewer edges than G,_, has, it follows from the 
fact that x is adjacent to y but not to v that there exists a vertex t # y in 
V — K which is adjacent to v but not to y. Now tx must be an edge of G, for 
otherwise {t, x, y,v} would induce a copy of 2K,. Similarly, tu¢ E, for 
otherwise {f, x, y, u} would induce a copy of C,. However, this implies that 
{t, x, y, u, v} induces a copy of C,, a contradiction. Therefore, S = V — K is 
stable, and G is a split graph. | 


A characterization of when a split graph is also a comparability graph 
appears in Chapter 9 (Theorem 9.7). 


3. Degree Sequences and Split Graphs 


A sequence A = [d,,d,,...,d,] of integers,n —1>d, >d,>--->4d, 
> 0, is called graphic if there exists an undirected graph having A as its degree 
sequence. For example, the sequence [2, 2, 2, 2] corresponds to the chordless 
4-cycle C,, while the sequence [2, 2, 2, 2, 2,2] corresponds to both 2K, and 
C,. It is easy to construct sequences which are not graphic, such as [1, 1, 1] 
and [4, 4, 2, 1, 1]. 

A simple necessary condition for a sequence to be graphic comes from 
Euler’s theorem: The sum )'d,; must be even. However, as the preceding 
example shows, an even sum is not sufficient to insure graphicness. Two 
classical theorems characterizing graphic sequences will now be stated. 


Theorem 6.4 (Havel [1955], Hakimi [1962]). A sequence A of integers 
n—-1l>d,>d,>--->d, > 0is graphic ifand only if the modified sequence 
A’ = [d, — 1,dy — 1,...,dg,41 — Le dg4a.---5 dal 

(sorted into decreasing order) is graphic. 


Theorem 6.5 (Erdés and Gallai [1960]). A sequence ofintegersn —1>d, 
2d, >--->d, > 0is graphic if and only if 


(i) > d,iseven, and 
i=1 


(ii) xy dj<rr-—1+ min{r, d;}, 


i=rt1 


forr = 1,2,...,n—1. 
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The inequality (ii) will be called the rth Erdés—Gallai inequality (EGI). 
Shortly, we shall give a characterization of split graphs in terms of these 
inequalities. We shall not prove Theorem 6.4 or Theorem 6.5 here since a 
very readable treatment can be found in Harary [1969, Chapter 6]. Both of 
these theorems suggest algorithms for testing whether or not a given sequence 
is graphic (Exercise 6). 

A third classical theorem on graphic sequences depends partly on the 
following observation. Let x, y, z, and w be distinct vertices of G with xy and 
zw edges of G and xz and yw nonedges of G. If we replace the two edges by 
the two nonedges, the resulting graph G’ will have the same degree sequence 
as G (see Figure 6.2). Such a replacement will be called an interchange. A 
stronger result holds, which we now state. 


Remark 6.6. Provided that we allow graphs to have multiple edges, if 
two graphs have the same degree sequence, then each can be obtained from 
the other by a finite sequence of interchanges. 


A proof of Remark 6.6 can be found in Ryser [1963, Chapter 6, Theorem 
3.1] by applying his technique to the edges-versus-vertices incidence matrix 
of G. 

A general question arises: What graph theoretic properties can be deter- 
mined solely from the degree sequence? In Section 2.5 we remarked that 
transitive tournaments could be recognized by the in-degrees of the vertices. 
Also, a characterization of trees in terms of degree sequences is known. We 
will now discuss this problem as applied to split graphs. 

Let A = [d,, d,,...,4,] be an integer sequence with n — 1 >d, >d,> 

->d, > 0, and let € = [0,1,2,...,n — 1]. Comparing the decreasing 
sequence A with the increasing sequence ¢, let us draw attention to the po- 
sition just prior to ¢ overtaking A. Let m be the largest index i such that 
d; = i — 1. Thus, either m = n and A is the degree sequence of K,, or d,, > 
m— landd,., <m. 

The next result characterizes split graphs as those for which equality holds 
in the mth Erd6s—Gallai inequality, where m is defined as above. 


Figure 6.2. A solid line denotes an edge of G; a broken line denotes a nonedge of G. An 
interchange replaces the two edges with the two nonedges. 
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Theorem 6.7 (Hammer and Simeone [1977]). Let G =(V, EF) be an 
undirected graph with degree sequence d, >d, >--->d,, and let m= 
max{i|d; > i — 1}. Then, Gis a split graph if and only if 


s d; = m(m — 1) + > d;. 


i=mt+1 


il 
- 


Furthermore, if this is the case, then w(G) = m. 


Proof. The theorem is true if G is a complete graph, so we may assume 
that d,, > m — landd,,,, < m. Since Ais nonincreasing, min{m, d;} = d; for 
i> m+ 1. Therefore, the mth EGI simplifies to 


s= VYd-<mm—-U+ Y d,. (1) 
i=1 i=m+1 


Let K denote the first m vertices of largest degree. The left summand of (1) 
splits into two contributions s = s,; + s,, where 


re 2 lize K|xzeE}| < m(m — 1), (2) 
i= 2 lye Klaye 8} 


VixeK|xyeE|< ¥ d,. (3) 
y¢K i=m+1 


Equality holds in (2) if and only if K is complete. Equality holds in (3) if 
and only if V — K is stable. Therefore, if equality holds in (1), then G is a 
split graph. 

Conversely, assume that G = (V, E) is a split graph. By Theorem 6.2 we 
can partition V into a stable set S and a complete set K such that | K| = w(G). 
Every vertex in K has degree at least |K | — 1, and, since K is maximum, every 
vertex in S has degree at most |K| — 1. Therefore, we may assume that the 
vertices are ordered so that K = {0,,..., Ujx)} and S = {v)x)41,---, U,}, where 
deg v,; = d;. Moreover, dix, =>|K|—1 and dixj4, <|K|—1<|K], so 
«w(G) = |K| = m. Finally, since K is complete and S = V — K is stable, we 
conclude that equality holds in (2) and (3) and therefore also in (1). | 


Corollary 6.8. If Gis a split graph, then every graph with the same degree 
sequence as G is also a split graph. 


Remark. Hammer and Simeone [1977] investigated a more general 
problem on graphs. They define the splittance of an arbitrary undirected 
graph to be the minimum number of edges to be added or erased in order to 
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produce a split graph. Of course, split graphs are just those graphs whose 
splittance is zero. Their main result shows that the splittance depends only 
on the degree sequence of the graph, and is given by the expression 


5 | men — 1 — Yd+ ¥ al 


i<m i=mt+1 
where m and the d; are as in Theorem 6.7. 


Those who have further interest in the topic of graphs and their degree se- 
quences are encouraged to read the survey paper by Hakimi and Schmeichel 
[1978]. 


EXERCISES 


1. Give necessary and sufficient conditions for a tree to be a split graph. 
Prove that your answer is correct. 

2. Prove that the Hamiltonian circuit problem is NP-complete for split 
graphs. (Hint. Use the fact that the Hamiltonian circuit problem is NP- 
complete for bipartite graphs.) 

3. How many nonisomorphic graphs are there with the following degree 
sequences: (i) [3,3,2,2,1,1],@i) [5,5,5,4,3,2], (iii) (5,5, 4, 3, 3, 3, 2, 1]? 
4. Give an example of two nonisomorphic split graphs having the same 
degree sequence. 

5. What is the splittance of graphs C,, K,,,,,mK,, and P,? 

6. Give an O(n) time algorithm for determining whether or not a nonin- 
creasing integer sequence n — 1 > d, >d, >--- 2d, > Ois graphic. Prove 
that your algorithm is correct and that its complexity is linear. 

7. Let A= [d,,d,,...,d,] be an integer sequence, and define A = [d,, 
d,,...,d,] by the formula 


d;=n—1—d,-j44 (i= 1,...,n). 


Show that A is graphic if and only if A is graphic. What can you say about the 
graphs corresponding to A and A? 

8. Let m= max{ild; >i-— 1} where n—12>d,>--->d,>0. Show 
that if the mth EGI holds, then the rth EGI automatically holds for r = 
m— 1,...,n (Hammer, Ibaraki, and Simeone [1978]). 

9. Prove Corollary 6.8 directly from Theorem 6.6. 


Research problem. Characterize those graphs which are uniquely deter- 
mined up to isomorphism by their degree sequence. R. H. Johnson has solved 
this problem for trees; the solution is the class obtained in Exercise 1. 
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CHAPTER 7 


Permutation Graphs 


1. Introduction 


In this chapter we consider a class of perfect graphs which has a large 
number of applications. Suppose z is a permutation of the numbers 1, 2,...,n. 
Let us think of z as the sequence [7,, Z2,..., 7,], 80, for example, the permu- 
tation z = [4, 3,6, 1, 5,2] has 2, = 4, 2, = 3, etc. Notice that (x~‘);, de- 
noted here as z; 1, is the position in the sequence where the number i can be 
found; in our example 231 = 1, 23! = 2, ete. 

We can construct an undirected graph G[z] from a in the following 
manner: G[z] has vertices numbered from | to n; two vertices are joined by 
an edge if the larger of their corresponding numbers is to the left of the 
smaller in x (that is, they occur out of their proper order reading left to right). 
In our example, both 4 and 3 are connected to 1 since they are each larger 
and to the left of 1, whereas neither 5 nor 2 is connected to 1 (see Figure 7.1). 
The graph G[z] is sometimes called the inversion graph of x. 

More formally, if x is a permutation of the numbers 1, 2,..., n, then the 
graph G[z] = (V, E) is defined as follows: 


VEAP Deas unt 
and 
je E (i —j)\(n;' —1j;') <0. 


An undirected graph G is called a permutation graph if there exists a permuta- 
tion z such that G = G[x]. 
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Figure 7.1. The graph G4, 3, 6, 1, 5, 2]. 


2. Characterizing Permutation Graphs 


Permutation graphs have many interesting properties. Notice what 
happens when we reverse the sequence x. Each pair of numbers which 
occurred in the correct order in z is now in the wrong order, and vice versa. 
Thus, the permutation graph we obtain is the complement of G[z]. In other 
words, if x” is the permutation obtained by reversing the sequence z, then 


G[x?] = Gf]. 


This shows that the complement of a permutation graph is also a permutation 
graph. 

Another property of the graph G[z] (which you may have already guessed) 
is that it is transitively orientable. If we orient each edge toward its larger 
endpoint, then we will obtain a transitive orientation F. For, suppose ij ¢ F 
and jk e F, then i <j <k and x; ' > 2; ' > 1, ', which implies that ike F. 
This result is only half of the story; we actually have the following: 


Theorem 7.1 (Pnueli, Lempel, and Even [1971]). An undirected graph G 
is a permutation graph if and only if G and G are comparability graphs. 


Proof. Suppose G = G[x]; then G is a comparability graph since G[z] 
has a transitive orientation. Likewise, G is a comparability graph since 
G = G[n’]. 

Conversely, let (V, F,) and (V, F,) be transitive orientations of G = (V, E) 
and G = (V,E), respectively. We claim that (V,F, + F) is an acyclic 
orientation of the complete graph (V, E + E). For suppose F, + F, hada 
cycle [v9, 01, 02,..., 0%), V9] of the smallest possible length /. If] > 3, then 
the cycle can be shortened either by vg v, or v2 v9, contradicting minimality. 
If | = 3, then at least two of the edges of the cycle are in the same F;, implying 
that F; is not transitive. Thus (V, F, + F,) is acyclic. Similarly (V, F;' + F2) 
is acyclic. 
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We conclude the proof by constructing a permutation a such that G = 
G[]. An acyclic orientation of a complete graph is transitive, and it deter- 
mines a unique linear ordering of the vertices. (See Section 2.5 on transitive 
tournaments.) Consider the following procedure. 

Step I. Label the vertices according to the order determined by F, + F.; 
namely, the vertex x of in-degree i — 1 gets label L(x) = i. 

Step II. Label the vertices according to the order determined by F;? + 
F,; namely, the vertex x of in-degree i — 1 gets label L’'(x) = i. 

Notice that 


xyeE<[L(x) — LY)][LL() — L(y] < 0, (1) 


since it is the edges of E which have their orientations reversed between steps I 
and II. This is the key to our argument. 

Step III. Define x as follows: For each vertex x, if L(x) = i, then 171 = 
L(x). The relationship is depicted in the commuting diagram below. 


V 


ie L 


ee, | ae ees by eee 


Therefore, by (1), 2 is the desired permutation and L is the desired iso- 
morphism. I 


Remark. In terms of the nomenclature of Section 5.8, G is a permutation 
graph if and only if the transitive orientations of G, when regarded as partial 
orders have dimension at most 2. 


The construction technique presented above is illustrated in Figure 7.2. 

Theorem 7.1 suggests an algorithm for recognizing permutation graphs, 
namely, applying the transitive orientation algorithm to the graph and to its 
complement. If we succeed in finding transitive orientations, then the graph 
is a permutation graph. To find a suitable permutation we can follow the 
construction procedure in the proof of the theorem. The entire method 
requires O(n*) time and O(n’) space for a graph with n vertices. 

We conclude this section with a remark which follows from transitive 
orientability. 


Remark. The decreasing subsequences of x and the cliques of G[x] are 
in one-to-one correspondence. The increasing subsequences of x and the 
stable sets of G[] are in one-to-one correspondence. 
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f b f 6 
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(Vv, Fi} 
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, F, (VY, 
Lfa/ =6 Lia/=4 
L(b) =2 
LH=4 b) = 
) Gi pase Lib) =6 
Licj=3 
Lie =5 4 = 
‘e) Lie) =\ Lich =2 
Lid) =| Lid) =3 
YF + Fe) Y, Fi + Fy) 


Figure 7.2. Construction of the permutation a = [5, 3, |, 6, 4, 2] from the transitive orienta- 
tions F, and F,. Vertex a gives zg ' = 4, vertex b gives ny | = 6, etc. 


3. Permutation Labelings 


A related, but simpler, problem is that of testing whether a given labeling 
of the vertices of a graph is a permutation labeling. Let G = (V, E) be an 
undirected graph, and let L:V—- {1,2,...,n} be a bijection labeling the 
vertices. We call L a permutation labeling if there exists a permutation x of 
{1, 2,...,n} such that 


xyeE (L(x) — L(y)][n (LQ) — m (L(y))] < 0. 


Clearly, G is a permutation graph if and only if it has at least one permutation 
labeling. 

Figure 7.3 shows two labelings of the same graph. The first is the permu- 
tation labeling already constructed in Figure 7.2. The second is not a per- 
mutation labeling for the following reason. Since Adj(1) = {5, 6}, both 5 
and 6 would be on the left of 1 while 2-4 would be on the right of 1 in any 
permutation z that might work. However, this implies that 3 and 4 would be 
to the right of 6—yet they are not connected to 6. Hence, no such permutation 
n exists for this labeling. 
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6 S 
4 2 4 2 
5 3 5 6 
4 4 
This labeling is This labeling is not 
a permutation labeling a permutation labeling 
Figure 7.3. 


Theorem 7.2 (Gill and Acharya [1977]). Let G = (V, E) be an undirected 
graph. A bijection L: V > {1, 2,..., n} is a permutation labeling of G if and 
only if the mapping 


F:x>L(x)— d(x) +d*@)— (xeV) 
is an injection, where 
d(x) = [ty € Adj(x)|LQ) < L(x)}| 
and 
d*(x) = |{ye Adj(x)|L(Qy) > LOX} 1. 


Proof. (=) Let a be a permutation corresponding to the labeling L. 
Then d(x) is the number of integers in 2 smaller than and to the right of 
L(x), and d*(x) is the number of integers in x larger than and to the left of 
L(x). By Exercise 4, f(x) = 27 '(L(x)), and since x7! and L are injective (in- 
deed bijective), so too is f. 

(<=) Assuming that f is injective, we will construct the desired permu- 
tation. Since d~ (x) < L(x) — 1 and d*(x) < n — L(x), it follows that 


l<f(ix)<n  (xeV). (2) 


But f is injective and integer valued, so (2) implies that f is a bijection from 
V to {1, 2,..., n}. Define z as follows: 


ni) = L(f~*(i) 


(see Figure 7.4). 
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V 
f L 
ye aoe | ear ete ee SR 
Figure 7.4. 


Now, 7 is a permutation, since L and f ~' are bijective. Furthermore, 


nm (L(x) = f(x) (xe V), 


so we must verify that 
xyeE (L(x) — LY) ILS) — fQ)] < 0. 


This is left as an exercise for the reader. | 


4. Applications 


Permutation graphs can be regarded as a class of intersection graphs in the 
following manner. Write the numbers 1, 2, ..., 2 horizontally from left to 
right; underneath them write the numbers z,, 22, ..., 2, nN Sequence, again 
horizontally left to right; finally, draw n straight line segments joining the 
two I’s, the two 2’s, etc. We call this the matching diagram of x (see Figure 7.5). 
Notice that the ith segment intersects the jth segment if and only if i and j 
appear in reversed order in 2; this is the same criterion for the vertices i and j 
of G[x] to be adjacent. Therefore, the intersection graphs of the segments of 
matching diagrams are exactly the permutation graphs. 

The reason for our introducing these matching diagrams is to assist us in 
studying some applications of permutation graphs. 


Figure 7.5. The matching diagram of [4, 3, 6, I, 5, 2]. 
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Application 7.1. Suppose we have two collections of cities, the X cities 
and the Y cities, lying, respectively, on two parallel lines. Suppose also, that 
there are airline routes connecting various X cities with various Y cities, all 
scheduled to be utilized at the same time of the day. Our mission, should we 
decide to accept it, will be to assign altitudes to each flight path so that inter- 
secting routes will be at different altitudes. We will thereby assure that no 
midair collisions will occur. Being clever graph theorists, we recognize this 
as a coloring problem. 

The data, as given, provides us with a bipartite graph embedded in the 
plane, as pictured in Figure 7.6. We number the flight paths by traversing the 
northern cities from west to east. From this we can extract a matching 
diagram, or go straight to the corresponding permutation graph G[z]. 
Assigning altitudes to the flight paths so that intersecting paths receive 
different altitudes is equivalent to coloring the vertices of G[z] so that 
adjacent vertices receive different colors. An efficient coloring algorithm for 
permutation graphs is given in the next section. 


(a) 


Figure 7.6. (a) A bipartite graph B representing flight paths between cities. (b) The matching 
diagram of a permutation z extracted from the bipartite graph B. (c) The graph G[z]. Color the 
vertices of G[z] and solve the altitude assignment problem for B. 
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Application 7.2 (Shifted Intervals). Let .% = {J;|i = 1,2,...,n} be a 
collection of intervals on a line, where I; = (x;, y;) and |/;| = y; — x; denotes 
the length of J;. Assume that the intervals, which may overlap, have been 
ordered such that x, < x. <--- < x,. Let w; represent the cost of shifting 
the interval I; (assumed to be independent of the distance shifted). Find the 
cheapest shifting of intervals so that (1) the order is preserved and (2) no 
overlap remains. (In Even, Pnueli, and Lempel [1972], the intervals cor- 
respond to the memory requirements of n programs at a certain time in a 
multiprogramming computer.) 

A solution to this problem is as follows. Consider the oriented graph 
(%, F) where 


U, [jer <= Mil S3j-— xi CG <S. 


isk<j 


Two intervals are thus related in F if and only if the intervals between them 
can be shifted in such a way that none of these j — i + 1 intervals (including 
the fixed J; and I,) will intersect. It is routine to show that F is a transitively 
oriented graph (see Exercise 5). The solution to our problem will be to find 
a chain of F having maximum weight (to remain, all others are shifted); in 
other words, find a maximum weighted clique of the graph E = F + F-! 
which is not only a comparability graph but is even a permutation graph. 


5. Sorting a Permutation Using Queues in Parallel 


A queue is a linear storage device in which items are loaded at one end and 
unloaded at the other end in a first-in—first-out fashion (FIFO). Let us 
consider the problem of sorting a permutation xz of the numbers 1, 2,...,n 


Qoutput Ornput 


o, 


Figure 7.7.. A network of k queues in parallel. 
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using a network of k queues arranged in parallel (see Figure 7.7). The permuta- 
tion sits in the input queue initially. Each number, in turn, passes along to one 
of the k internal queues where it is stored temporarily until it is moved onto 
the output queue. We assume that each queue has unbounded capacity and 
that backing up along an edge, counter to its direction, is forbidden. One can 
easily imagine a station master directing railroad cars through such a switch- 
yard in order to rearrange the cars of a freight train. Typically, the number 
of sidings (queues) will be limited, so we are led to the following problem. 
Given a network of k queues in parallel, characterize the permutations which 
can be sorted on it. Or similarly, given a permutation z, how many queues 
will we need? In addition, find an optimal sorting method. 


Example. Suppose x = [4, 3, 6, 1, 5,2]. The 4 is placed in Q,. The 3 
cannot go in Q, because it will be forever stuck behind the 4, so put it in Q). 
Next comes the 6, which can go either behind 4 on Q, or behind 3 on Q). 
Put 6 behind 4 on Q,. How about 1? It must go on Q;. The 5 cannot go on 
Q, because 6 is already there; put 5 on Q, behind 3. Finally 2 cannot go on Q, 
or Q,, but it can go on Q,. Now that everything is stored (Figure 7.8), we 
unload the numbers 1-6 from their respective storage places. 

We call your attention to a few obvious facts. The contents of each Q; must 
be in increasing order, for otherwise it would be impossible to successfully 
unload all the numbers in proper order. Furthermore, it is easy to show that 
it makes no difference whatsoever whether we (a) require loading all input 
numbers onto the queues before unloading any of them or (b) allow unloading 
anytime it is possible. 

What is it that forces two numbers to go into different queues? Answer: 
The numbers occur in reversed order in xz. Thus, if i and j are adjacent in 
G[x], then they must go through different queues. 


Proposition 7.3. Let a = [n,,7,...,7,] be a permutation of the in- 
tegers {1,2,...,n}. There is a one-to-one correspondence between the 


Figure 7.8. A network which is sorting x = [4, 3, 6, 1, 5, 2]. 
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proper k-colorings of G[z] and the successful sorting strategies for x in a 
network of k parallel queues. 


Proof. Assign painters to each Q,, each with a different color paint. Now 
sort x in the k-network and have every number painted as it enters its 
corresponding queue. Since connected vertices i and j of G[] pass through 
different queues, they receive different colors. 

Conversely, given a proper coloring of G[z] using colors 1, 2,..., k, assign 
a traffic director to the input queue. If the color of x is c, then the traffic 
director sends x to Q,. Suppose this strategy is unsuccessful. There must be a 
bottleneck in some queue, say Q,,; i.e, Q,, has a pair of numbers x and y 
stored in reversed order. However, x and y enter Q,, in the same order that 
they appear in z, namely, reversed. Thus, x and y are adjacent in G[7], and 
yet they are both colored the same, a contradiction. Clearly, this correspon- 
dence is a bijection. | 


Corollary 7.4. Let x be a permutation. The following numbers are 
equal: 


(i) the chromatic number of G[7], 
(ii) the minimum number of queues required to sort z, 
(iii) the length of a longest decreasing subsequence of z. 


Proof. The equivalence of (i) and (ii) follows immediately from Propo- 
sition 7.3, and its proof suggests a method for transforming a solution of one 
problem into a solution of the other. Equality between (1) and (ii) holds since 
a longest subsequence of x corresponds to a maximum clique of G[], which 
will be of size y(G[]) since permutation graphs are perfect. I 


The canonical sorting strategy for x places each number in the first available 
queue. (Our example was done that way.) From this strategy, we obtain the 
canonical coloring of G[{x]. The following algorithm simulates the process. It 
yields a minimum coloring. 


Algorithm 7.1. Canonical coloring of a permutation. 
Input: A permutation x = [1,,72,...,,] of the numbers {1,2,...,n}. 
Output: A coloring of the vertices of G[x] and the chromatic number x of 
G[x]. 
Method: During the jth iteration, 7; is transferred onto the queue Q; having 
smallest index i satisfying x; > last entry of Q; (ic., the first allowable Q;). 
We do not actually save the entire contents of Q;. Instead, an array LAST(i) 
holds the last number in Q;. The counter k keeps track of the actual number of 
queues (colors) used. The entire algorithm is as follows: 
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begin 
1 k<-90; 
2. for j — 1 tondo 
begin 
3. i ~ FIRST allowable queue; 
4, COLOR(z;) — i; 
5. LAST(i) < 1,; 
6. k — max{k, i}; 
end 
7. Lo k; 


end 


In order to execute statement 3 efficiently, a type of binary insertion can be 
used. One such subroutine is given in Figure 7.9. The next result shows the 
correctness of Algorithm 7.1. 


Theorem 7.5. Let 2 be a permutation of the numbers {1, 2,..., n}. The 
canonical coloring of G[], as produced by Algorithm 7.1, is a minimum 
coloring. 


Proof. Clearly, Algorithm 7.1 produces a proper y-coloring of G[x]. We 
must show that y = y(G[z]). It is sufficient to show that a has a decreasing 
subsequence of length y. Consider the predecessor function p defined as 
follows: If COLOR(x,) = i > 2, then z,,, equals the value of LAST(i — 1) 
during the jth iteration. Clearly, 2.) > 2; and p(j) < j since it was z,,, sitting 
on Q;_ , which forced 2; to go down to Q;. Then 


Rij Tia» aay Tj, 
where 
COLOR (z;,_) =X 
and 
Ri. = Meu for aad Fe Glee) Cree 
is the desired decreasing subsequence. | 
procedure FIRST allowable queue: 
begin 
tie lbtrek +1; 
until i = ¢ do 
begin 


re l@+ 9/2]; 
if x; > LAST(r) 
then <r; 
elseicr+ 1; 
end 
return i; 
end 


Figure 7.9. 
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Remark. To find a minimum clique cover of G[z], apply Algorithm 7.1 
to the reversal x? of z. 

Algorithm 7.1 can be used to color any permutation graph G in time 
proportional to nlogn provided we have the permutation x and the iso- 
morphism G —> G[x]. Notice that this complexity is independent of the 
number of edges of G. If we do not have z, then we would revert to the 
coloring algorithm for comparability graphs. 


Remark. If we apply the algorithm in Exercise 8 of Chapter 2 to the 
orientation F of G[z] where each edge is oriented toward its larger endpoint, 
then the coloring we obtain will be exactly the same as the canonical coloring, 
namely, 


COLOR(x,) = i HEIGHT(x,) =i — 1. 


EXERCISES 


1. For what permutation z of the numbers 1, 2,3,...,n is G[] the following: 

(a) the complete graph on n vertices; 

(b) the graph of n isolated vertices; 

(c) two disjoint complete graphs on r and n — r vertices, respectively? 
2. Find a permutation x whose graph G[z] is isomorphic to G,. Do the 
same for G, (see Figure 7.10). 


AX On 


2 
Figure 7.10. 


3. Let 27! be the inverse of the permutation z. Prove that G[z] = G[x~ *]. 
4. Letx =[n,, m,...,7,] be a permutation of {1, 2,..., n}. Let p; denote 
the number of integers less than and to the right of i in x, and let q; denote the 
number of integers greater than and to the left of i in x. Prove that the 
following equality holds: 


nm) + pp=it qi. 


5. Let F be defined as in Application 7.2 (the shifted interval problem), and 
letE=FUF", 

(i) Show that F is a transitive orientation of E. 

(ii) Prove that E is a permutation graph. 
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6. Give an application similar to Application 7.2 which uses the fact proved 
in Exercise 5(ii), namely, that E is not only a comparability graph, but is 
even a permutation graph. 

7. A permutation graph G is uniquely representable if there is only one 
permutation z such that G[x] = G. Characterize the uniquely representable 
permutation graphs. 

8. Let G be a permutation graph with n vertices. Given transitive orienta- 
tions F, and F, of G and G, respectively, write an algorithm which calculates 
a permutation z such that G[z] = G. Show that your algorithm can run in 
O(n?) time. 

9. Using the canonical sorting strategy, give a minimum coloring of the 
graph G[x] for z = [9, 8, 2, 5, 6, 1, 7, 4, 3). 

10. In sorting, using a network of parallel queues, prove that it makes no 
difference whether we (a) require loading all input numbers onto the queues 
before unloading any of them or (b) allow unloading anytime it is possible. 
11. Prove the following: At any point during the execution of Algorithm 7.1, 


LAST(1) > LAST(2) > «+ > LAST(). 


Why is this fact needed to justify the correctness of the subroutine in Figure 
7.9? Analyze the time complexity of Algorithm 7.1. 

12. Let G be a permutation graph with n vertices. Show that either G or G 
contains a clique of size [n'/*] (Erdés and Szekeres [1935]). 
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CHAPTER 8 


Interval Graphs 


1. How It All Started 


In 1957 G. Hajés posed the following problem: 


Given a finite number of intervals on a straight line, a graph associated 
with this set of intervals can be constructed in the following manner: 
each interval corresponds to a vertex of the graph, and two vertices are 
connected by an edge if and only if the corresponding intervals overlap 
at least partially. The question is whether a given graph is isomorphic to 
one of the graphs just characterized (Hajés [1957, p. 65, translated by 
M.C.G.]). 


Independently, the well-known molecular biologist, Seymour Benzer, 
during his investigations of the fine structure of the gene, asked a related 
question. 


From the classical researches of Morgan and his school, the chromosome 
is known as a linear arrangement of hereditary elements, the genes. 
These elements must have an internal structure of their own. At this 
finer level, within the gene the question arises again: . . . Are they [the 
subelements within the gene] linked together in a linear order analogous 
to the higher level of integration of the genes in the chromosome? 

A crucial examination of the question should be made from the point 
of view of topology, since it is a matter of how parts of the structure are 
connected to each other, rather than of the distances between them. 
Experiments to explore the topology should ask qualitative questions 
(e.g., do two parts of the structure touch each other or not?) rather than 
quantitative ones (how far apart are they?). (Benzer [1959].) 
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The solution to this question would be found by studying those graphs 
which represent intersecting intervals on a line, and then verifying whether 
or not the data that was gathered was consistent with the linear genetic 
hypothesis. 

Our treatment of interval graphs began in Chapter 1. Let us continue 
looking into the properties of this interesting and useful class of graphs. The 
reader may wish to review Section 1.3 at this point. 


2. Some Characterizations of Interval Graphs 


The following theorem and its corrollary will establish where the class of 
interval graphs belongs in the world of perfect graphs. 


Theorem 8.1 (Gilmore and Hoffman [1964]). Let G be an undirected 
graph. The following statements are equivalent. 


(i) Gis an interval graph. 
(ii) G contains no chordless 4-cycle and its complement G is a com- 
parability graph. 
(iii) The maximal cliques of G can be linearly ordered such that, for every 
vertex x of G, the maximal cliques containing x occur consecutively. 


Proof. (i) = (it) This was proved in Chapter 1, Propositions 1.2 and 1.3. 


(ii) => Gii) Let us assume that G = (V, E) contains no chordless 4-cycle, 
and let F be a transitive orientation of the complement G. 


Lemma A. Let A, and A, be maximal cliques of G. 


(a) These exists an edge in F with one endpoint in A, and the other 
endpoint in A. 

(b) All such edges of E connecting A, with A, have the same orientation 
in F, 


Proof of Lemma A. (a) If no such edge exists in F, then A, U A, is a 
clique of G, contradicting maximality. 

(b) Suppose abe F and dee F with a,c € A, and b,d € A,. We must show 
a contradiction. If either a = c or b = d, then transitivity of F immediately 
gives a contradiction; otherwise, these four vertices are distinct (Figure 8.1), 
and ad or bc is in E, since E may not have a chordless 4-cycle. Assume, 
without loss of generality, that ade E; which way is it oriented? Using the 
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Figure 8.1. Solid edges are in E; broken edges are in E. Arrows denote the orientation F. 


transitivity of F, ad € F (resp. da € F) would imply ac é€ F (resp. db € F), which 
is impossible, and Lemma A is proved. 


Consider the following relation on the collection @ of maximal cliques: 
A, < A, iff there is an edge of F connecting A, with A, which is oriented 
toward A,. By Lemma A, this defines a tournament (complete orientation) 
on @. We claim that (@, <) is a transitive tournament, and hence linearly 
orders @. For suppose A, < A, and A, < A;; then there would be edges 
wx € F and yze F with we A,, x,ye Az, and ze A;3. Ifeither xz ¢ Eorwy¢ E, 
then wze F and A, < A;. Therefore, assume that the edges wy, yx, and xz 
are all in E (see Figure 8.2). Since G contains no chordless 4-cycle, wz ¢ E, 
and the transitivity of F implies wze F. Thus A, < A3, which proves the 
transitive tournament claim. 

Next, assume that @ has been linearly ordered A,, Az,..., A,, according 
to the relation above (ie., i < jiff A; < A,). Suppose there exist cliques 
A; < A; < A, with xe A,,x¢Aj,, and xe A,. Since x ¢ A;, there is a vertex 
yeA, such that xy ¢ E. But A; < A; implies xy € F, whereas A; < A, implies 
yx € F, contradiction. This proves (iii). 

(iii) > (i) For each vertex xe V, let I(x) denote the set of all maximal 
cliques of G which contain x. The sets I(x), for x € V, are intervals of the 
linearly ordered set (@, <). It remains to be shown that 


xyeEoI(x)nliy) 4 Oo (x, ye V). 


This obviously holds, since two vertices are connected if and only if they are 
both contained in some maximal clique. 


Figure 8.2. 
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Corollary 8.2. An undirected graph G is an interval graph if and only if 
G is a triangulated graph and its complement G is a comparability graph. 


Remark. The coloring, clique, stable set, and clique cover problems can 
be solved in polynomial time for interval graphs by using the algorithms of 
Chapters 4 and 5. A recognition algorithm can be obtained by combining 
Algorithms 4.1 and 5.2, although the recognition algorithm to be presented 
in Section 8.3 will be asymptotically more efficient. 


Statement (iii) of the Gilmore-Hoffman theorem has an interesting 
matrix formulation. A matrix whose entries are zeros and ones, is said to have 
the consecutive 1’s property for columns if its rows can be permuted in such a 
way that the 1’s in each column occur consecutively. In Figure 8.3 the matrix 
M, has the consecutive 1’s property for columns since its rows can be 
permuted to obtain M,. Matrix M, does not possess the property. Consider 
the clique matrix M (maximal cliques-versus-vertices incidence matrix) of a 
graph G. The following corollary to Theorem 8.1 is immediate. 


Theorem 8.3 (Fulkerson and Gross [1965]). An undirected graph G is an 
interval graph if and only if its clique matrix M has the consecutive 1’s 
property for columns. 


Proof. An ordering of the maximal cliques of G corresponds to a permu- 
tation of the rows of M. This theorem follows from Theorem 8.1. | 


The earliest characterization of interval graphs was obtained by Leker- 
kerker and Boland. Their result embodies the notion that an interval graph 
cannot branch into more than two directions, nor can it circle back onto 
itself. 


Theorem 8.4 (Lekkerkerker and Boland [1962]). An undirected graph G 
is an interval graph if and only if the following two conditions are satisfied: 


(i) Gisa triangulated graph, and 

(ii) any three vertices of G can be ordered in such a way that every path 
from the first vertex to the third vertex passes through a neighbor of the 
second vertex. 


Three vertices which fail to satisfy (ii) are called an astroidal triple. They 
would have to be pairwise nonadjacent, but any two of them would have to be 
connected by a path which avoids the neighborhood of the remaining vertex. 
Thus, G is an interval graph if and only if G is triangulated and contains no 
astroidal triple. Condition (ii) illustrates a well-known law of the business 
world: Every shipment from a supplier to the consumer must pass by the 
middie man. 
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Figure 8.3. Matrix M, has the consecutive 1’s property for columns since it can be trans- 
formed into M,. Matrix M; does not have the consecutive 1’s property for columns since it 
cannot be suitably transformed. 


3. The Complexity of Consecutive 1’s Testing 


Interval graphs were characterized as those graphs whose clique matrices 
satisfy the consecutive 1’s property for columns (Theorem 8.3). We may 
apply this characterization to a recognition algorithm for interval graphs 
G = (V,E) in a two-step process. First, verify that G is triangulated and, if 
so, enumerate its maximal cliques. This can be executed in time propor- 
tional to |V| + |E| (Corollary 4.6, Theorem 4.17) and will produce at most 
n = |V| maximal cliques (Proposition 4.16). Second, test whether or not the 
cliques can be ordered so that those which contain vertex v occur con- 
secutively for every ve V. Booth and Leuker [1976] have shown that this 
step can also be executed in linear time. We shall look at the main ideas 
behind their algorithm and its implementation. The interested reader should 
consult their very readable paper for additional details. Subject to Corollary 
8.8 and Exercise 3 we have the following. 


Theorem 8.5 (Booth and Leuker [1976]). Interval graphs can be recog- 
nized in linear time. 


The general consecutive arrangement problem is the following: Given a 
finite set X and a collection ¥ of subsets of X, does there exist a permutation 
nx of X in which the members of each subset I €.% appear as a consecutive 
subsequence of m? In the interval graph problem, X is the set of maximal 
cliques and % = {I(v)},-y, where I(v) is the set of all maximal cliques con- 
taining v. The consecutive arrangement and consecutive 1’s problems are 
equivalent: The rows of the matrix constitute X, and each column determines, 
or is determined by, a subset of X consisting of those rows containing a 1 in 
the specified column. Tucker [1972] has characterized the consecutive 1’s 
problem in terms of forbidden configurations. Another characterization, due 
to Nakano [1973a], is stated as Exercise 12. 
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Figure 8.4. A PQ-tree. 


Besides its use in recognizing interval graphs, the consecutive 1’s problem 
has a number of other applications. These include a linear-time algorithm 
for recognizing planar graphs (see Booth and Leuker [1976]), and a storage 
allocation problem to be discussed in the next section (Application 8.4). 

The data structure needed to solve the consecutive arrangement problem 
most efficiently is the PQ-tree. PQ-trees were invented by Leuker [1975] and 
Booth [1975] expressly for this purpose. They are used to represent all the 
permutations of X which are consistent with the constraints of consecutivity 
determined by %. Most importantly, only a small amount of storage is 
required for this representation. 

A PQ-tree T is a rooted tree whose internal nodes are of two types: P and 
Q. The children of a type P-node occur in no particular order, while those of a 
Q-node appear in an order which must be locally preserved. This will be 
explained in the next paragraph. We designate a P-node by a circle and a 
Q-node by a wide rectangle. The leaves of T are labeled bijectively by the 
elements of the set X (see Figure 8.4). 

The frontier of a tree T is the permutation of X obtained by reading 
the labels of the leaves from left to right. In our example, the frontier is 
{[ABCDEFGHIJ]. Two PQ-trees T and T' are equivalent, denoted 
T = T’, if one can be obtained from the other by applying a sequence of the 
following transformation rules. 


1. Arbitrarily permute the children of P-node. 
2. Reverse the children of a Q-node. 


Figure 8.5 illustrates a PQ-tree which is equivalent to the tree in Figure 8.4. 
Its frontier is [F J 1 G H A B E D C}. Parenthetically, we obtain an equivalent 
tree by regarding T as a mobile and exposing it to a gentle summer breeze. 
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Figure 8.5. A PQ-tree equivalent to the tree in Figure 8.4. 


Finally, any frontier obtainable from a tree equivalent with Tis said to be 
consistent with T, and we define 


CONSISTENT(T) = {FRONTIER(T’)|T’ = T}. 


It can be shown that the classes of consistent permutations of PQ-trees form 
a lattice. The null tree Ty has no nodes and CONSISTENT(T)) = @. The 
universal tree has one internal P-node, the root, and a leaf for every member of 
X (Figure 8.6). 

Let us now relate PQ-trees to the consecutive arrangement problem. Let ¥ 
be a collection of subsets of a set X, and let II(.%) denote the collection of all 
permutations x of X such that the members of each subset J €.4% occur 
consecutively in x. For example if % = {{A, B, C}, {A, D}}, then (A) = 
{[D ABC], [DAC B],[C BAD], [BC AD]}. We have the following im- 
portant correspondence. 


Theorem 8.6 (Booth and Leuker [1976]). (i) For every collection of 
subsets ¥% of X there exists a PQ-tree T such that II(.%) = CONSISTENT(T). 


(ii) For every PQ-tree T there exists a collection of subsets .¥ such that 
i. 4%) = CONSISTENT(T). 


*o x, 


X = {X1,X2, 2055 x,}. 
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Note that the effect of Q-nodes is to restrict the number of permutations by 
making some of the brother relationships rigid. We leave it to the reader to 
verify that the tree in Figure 8.4 corresponds to the collection 


I = {{A, B}, {C, D}, {D, E}, {B, C, D, E}, (1, J}, (G, H}, {G, H, I}}. 
The following procedure clearly calculates TI(.¥). 


procedure CONSECUTIVE(Y, .¥): 
begin 
1. TI] — {x|z is a permutation of X}; 
2. foreach Je # do 
3. Tl — 1] nm {x|the members of J occur consecutively in z};; 
4. return IT; 
end 


Any naive implementation of this algorithm would be impractical because of 
the initially exponential size of IT. However, using PQ-trees we can represent 
II with only O(|X|) space. The equivalent program using PQ-trees is as 
follows. 


procedure CONSECUTIVE(Y, -¥): 
begin 
1. T « universal tree; 
2. for each Je ¥ do 
3. T — REDUCE(T, );; 
4 return 7; 
end 


This version makes use of a pattern matching routine REDUCE which 
attempts to apply a set of 11 templates. Each template consists of a pattern 
to be matched against the current PQ-tree and a replacement to be substituted 
for the pattern. The templates are applied from the bottom to the top of the 
tree. The null tree may be returned when no template applies. Two examples 
are illustrated in Figure 8.7. For details of the algorithm, the reader is directed 
to Booth and Leuker [1976]. There you will find the templates, a detailed 
version of the algorithm, a proof of correctness, and a proof of the following 
complexity theorem. 


Theorem 8.7 (Booth and Leuker [1976]). Theclass of permutations II(.4) 
can be computed in O(|.%| + |X| + SIZE|.4|) steps where SIZE(.4%) = 


YreslII- 


In the theorem the word computed means computed in its PQ-tree repre- 
sentation T. In the consecutive arrangements problem it is not necessary to 
calculate all of TI(.4). Rather, it is enough to produce one member of IT(¥) or 
to determine that II(%) is empty. This can be done very simply by calculating 
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Figure 8.7. Two illustrations of the procedure CONSECUTIVE (PQ-tree version). The 
reductions make use of the templates in Booth and Leuker [1976]. 


FRONTIER(T). In the next section we suggest an application in which the 
permutations of II(.4) may have to be compared according to secondary 


criteria. 


Corollary 8.8. Let M be a (0, 1)-valued matrix with m rows, n columns, 
and f nonzero entries. Then, M can be tested for the consecutive 1’s property 


in O(m + n + f) steps. 


Remark. IfMissparse(f < mn), then M would not be stored as an array. 
Rather, either a list of the nonzero entries or row lists of M would be used 


(Chapter 2). 
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cococ=- 


Figure 8.8. Matrix M, has the circular !’s property for columns since its rows can be per- 
muted to yield M,. Matrix M; does not have this property. 


A (0, 1)-valued matrix has the circular I’s property for columns if its 
rows can be permuted in such a way that the 1’s in each column occur in a 
circular consecutive order; regard the matrix as wrapped around a cylinder. 
In Figure 8.8 the matrix M, has the circular 1’s property since its rows can 
be permuted to obtain M,. However, M, does not have the circular 1’s 
property. 


Remark 1. M has circular 1’s if and only if it has circular 0’s. 


Remark 2. The circular 1’s property is preserved under complementation 
of any column, i.e., interchanging ones and zeros. 


The circular 1’s property was introduced by Ryser [1969]. 

Clearly, consecutive 1’s implies circular 1’s, but not conversely. Nonethe- 
less, one can verify the latter property using a test for the former, as follows. 

Let M be a (0, 1)-valued matrix, and let M’ be obtained from M by com- 
plementing those columns with a 1 in the kth row (k chosen arbitrarily). 


Theorem 8.9 (Tucker [1970, 1971]). Matrix M has the circular 1’s 
property if and only if M’ has the consecutive 1’s property. 


Proof. By Remark 2, if M has the circular 1’s property, then so does M’. 
By cyclically permuting the rows of M’ so that the kth row (containing only 
zeros) is moved to the top, we shall obtain a matrix with consecutive 1’s in 
each column. Conversely, if M’ has the consecutive 1’s property, then M’ 
also has the circular 1’s property. Hence, Remark 2 implies that M has the 
circular 1’s property. | 


The efficiency of testing for circular 1’s and consecutive 1’s depends partly 
upon the sparseness of M. Thus, if M is sparse we shall want to choose k so 
that M’ is also sparse. This can always be done provided M is stored as a list 
of its nonzero entries or by row lists. 


Theorem 8.10 (Booth [1975]). An m x n (0, 1)-valued matrix M with 
f nonzero entries can be tested for the circular 1’s property in O(m + n+ f) 
steps. 
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Proof. Let M be given asa list L of its nonzero entries. Testing for circular 
1’s can be accomplished as follows. 

Step I. Scan L once, setting up row lists for M and counting the number 
c; of ones in each row i: O(m + f). 

Step II. Choose a row k having minimum number of 1’s: O(m). 

Step III. Form M’ by complementing the appropriate columns. This 
may be carried out by scanning each row in parallel with row k, or by using 
an auxiliary Boolean n-vector, as illustrated in Appendix B: O());(c; + ¢,)) = 
Om + f). 


Remark. M’ has at most 2f nonzeros since each row is at most doubled 
in its number of ones. 


Step IV. Test M’ for consecutive 1’s:O(m + n + 2f) = O(m+n+ f). ff 

We have seen that testing a given matrix M for the consecutive or circular 
1’s properties can be executed efficiently. It is natural to ask, if M does not 
satisfy one or both of these properties, whether certain columns of M can be 
deleted in order that the remaining matrix satisfies the property. In general 
this problem is very difficult to answer. 


Theorem 8.11 (Booth [1975]). Let M be an r x c (0, 1)-valued matrix, 
and let k be an integer (k < c). Deciding whether or not there exists anr x k 
submatrix of M satisfying the consecutive 1’s property (or the circular 1’s 
property) is NP-complete. 


A proof follows from Exercise 15. 


Kou [1977] presents two other extensions of the consecutive 1’s property 
which are also NP-complete: 


(1) minimizing the number of consecutive blocks of 1’s appearing in the 
columns; 

(2) minimizing the number of times a row must be split into two pieces to 
obtain consecutive 1’s. 


4. Applications of Interval Graphs 


Interval graphs are among the most useful mathematical structures for 
modeling real world problems. The line on which the intervals rest may 
represent anything that is normally regarded as one dimensional. The 
linearity may be due to physical restriction, such as blemishes on a micro- 
organism, speed traps on a highway, or files in sequential storage in a com- 
puter. It may arise from time dependencies as in the case of the life span of 
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persons or cars, or jobs on a fixed time schedule. A cost function may be the 
reason as with the approximate worth of some fine wines or the potential for 
growth of a portfolio of securities. And so the list goes on. 

The task to be performed on an interval graph will vary from problem to 
problem. If what is required is to find a coloring or a maximum weighted 
stable set or a big clique, then fast algorithms are available. If a Hamiltonian 
circuit must be found, then there are no known efficient algorithms (unless 
the graph has more structure than just being an interval graph). Also, the 
speed with which such a problem can be solved will depend partially on 
whether we are given simply the interval graph G or, in addition, an interval 
representation of G. 

Let us direct our attention to a few interesting applications of interval 
graphs. 


Application 8.1. Suppose c,, c,,..., ¢, are chemical compounds which 
must be refrigerated under closely monitored conditions. If compound c; 
must be kept at a constant temperature between t; and t; degrees, how many 
refrigerators will be needed to store all the compounds? 

Let G be the interval graph with vertices c,,c,,...,c¢, and connect two 
vertices whenever the temperature intervals of their corresponding com- 
pounds intersect. By the Helly property (Section 4.5), if {c;,,¢;,,..-,¢,,} 8 a 
clique of G, then the intervals {{f;,, t;,]|j = 1,2,..., k} will have a common 
point of intersection, say ¢. A refrigerator set at a temperature of ¢ will be 
suitable for storing all of them. Thus, a solution to the minimization problem 
will be obtained by finding a minimum clique cover of G. 


Application 8.2. Benzer’s problem, as stated in the introduction to this 
chapter, asks if the subelements inside the gene are linked together in a linear 
arrangement. To answer this question data were gathered on mutations of the 
gene. For certain microorganisms a mutant form may be assumed to arise 
from the standard form by alteration of some connected part of the internal 
structure. By experiment it can be determined whether or not the blemished 
part of two mutant genes intersect. (We would hope to show that the blem- 
ished parts are linear.) 

From a large collection of mutants we obtain the pairwise intersection data 
of their blemishes and consider its intersection graph G. Are the intersection 
data compatible with the hypothesis of linearity of subelements in the gene? 
Equivalently, is G an interval graph? A positive answer does not confirm 
linearity! However, if the data are correct, a negative answer definitely 
refutes the hypothesis. Benzer experimented on the virus Phage T4; his 
findings were consistent wih linearity (see Benzer [1959, 1962] and Roberts 
{1976]). 
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Cohen, Komlds, and Mueller [1979] have shown that the asymptotic 
probability P,, , that a random graph with n vertices and e edges is an interval 
graph satisfies 


Ps OF exp(— A) 


for large n and e and not too large e®/n> where A = 32e°/3n5. From this result 
and from some Monte Carlo estimates, they suggest, “it appears that the 
chance that Benzer observed an interval graph by chance alone is nearly 
zero.” For related results see Cohen (1968, 1978] and Hanlon [1979a, 1979b]. 
The phenomenon of overlap in biology has been brought to light again 
recently. Kolata [1977] surveys some of these developments. She writes, 


Since the early days of molecular biology, genes have been pictured as 
nonoverlapping sequences of DNA [within the chromosome]. Detailed 
studies of a few bacterial and viral genes confirmed this view, and most 
investigators did not question it. [Furthermore,] the hypothesis of 
non-overlapping genes is a keystone for many genetic theories. [How- 
ever, recent evidence seems to suggest that] viral genes and possibly 
bacterial genes may overlap. None of the studies with bacteria provide 
incontrovertible evidence that genes overlap, but all suggest that this 
phenomenon occurs. [If overlapping genes do exist.] current views of 
gene organization and the control of gene expression, as well as views of 
the information content of DNA molecules and the effects of mutations 
in DNA, may have to be substantially revised. [Science 176, 1187-1188 
(1977), copyright 1977 by the American Association for the Advance- 
ment of Science.] 


Application 8.3. In archaeology seriation is the attempt to place a set of 
items in their proper chronological order. At the turn of the century, Flinders 
Petrie, a well-known archaeologist, formulated this problem, calling it 
“sequence dating,” while studying 800 types of pottery found in 900 Egyptian 
graves. This problem has much in common with interval graphs and the 
consecutive 1’s property. Let A be a set of artifacts (or aspects of artifacts) 
which have been discovered in various graves. To each artifact there ought to 
correspond a time interval (unknown to us) during which it was in use. To 
each grave there corresponds a point in time (also unknown) when its 
contents were interred. Our problem ts to figure out these time relationships. 


(a) Consider the incidence matrix M whose rows represent the graves 
and whose columns represent the artifacts which either are or are not 
present in a given grave. Under the assumption that a grave contains every 
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member of A in use at the time of burial, the matrix M will have the con- 
secutive 1’s property for columns. Each permutation of the rows which gives 
consecutive 1’s corresponds to an acceptable seriation of the graves and 
defines a possible interval assignment for A. Since there may be many of 
these, other methods will also have to be used to further limit the possibilities. 

(b) Consider the graph G whose vertices represent the artifacts with two 
vertices being connected by an edge if their corresponding artifacts are found 
in some common grave. Under the assumption that every pair of artifacts 
whose usage intervals intersect are to be found together in some grave, we 
have the G is an interval graph and any interval assignment for G would be a 
candidate for the usage intervals of A. As before, additional techniques are 
required to choose the correct assignment. (See Kendall [1969a, 1969b], 
Hodson, Kendall, and Tautu [1971], and Roberts [1976].) One further 
drawback to practical application is that there may be incomplete data so 
that the assumptions are not satisfied. 


Application 8.4. Let X represent a set of distinct data items (records) and 
let ¥ be a collection of subsets of X called inquiries. Can X be placed in 
linear sequential storage in such a way that the members of each I €.¥ are 
stored in consecutive locations? When this storage layout is possible, the 
records pertinent to any inquiry can be accessed with two parameters, a 
starting pointer and a length. Ghosh [1972, 1973] calls this the consecutive 
retrieval property; it is clearly a restatement of the consecutive arrangement 
property. Thus, the question can be answered efficiently using PQ-trees 
(Section 8.3). For related results see Nakano [1973a, 1973b], Ghosh [1974, 
1975], Waksman and Green [1974], Patrinos and Hakimi [1976], L. T. 
Kou [1977], and Gupta [1979]. For an application of the circular 1’s 
property to cyclic staffing problems, see Bartholdi et al. [1977]. 


Commentary 


Application 8.5. At the Typical Institute of Mathematical Sciences 
(TIMS) each new faculty member visits the coffee lounge once during the 
first day of the semester and meets everyone who is there at the time. How 
can we assign the new faculty members to alcoves of the coffee lounge in 
such a way that no one ever meets a new person during the entire remainder 
of the semester? This is clearly a coloring problem on an interval graph. No 
specific algorithm is needed, however, since it usually happens naturally. 

Additional applications of consecutive and circular 1’s to such areas as 
file organization and cyclic staffing appear in the bibliography at the end of 
the chapter. 
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5. Preference and indifference 


Let V be a set. Let us assume that, for every pair of distinct members of V, 
a certain decision maker either clearly prefers one over the other or he feels 
indifferent about them. What is the nature of his preferences, and can they 
be quantified in an orderly manner? What does this imply about his decision 
processes? 

We construct two graphs H = (V,P) and G =(V,E) as follows. For 
distinct x, ye V, 


xy é P =x is preferred over y, 
xy € E = indifference is felt between x and y. 


By definition, H = (V, P) is an oriented graph, G = (V, E) is an undirected 
graph, and (V, P + P~' + E) is complete. 

What should we expect from the structure of H? If H has a cycle, then our 
decision maker is likely to be confused and is probably wasting time running 
around in circles. 

Therefore, it is reasonable to require H to be acyclic. In fact, we would 
want H to be transitive. After all, if x is preferred over y and y is preferred 
over Z, it is unlikely that a discriminating person would feel indifferent about 
x and z. Thus, we require that P be a partial order.* 

Our example is not as whimsical as it may at first seem. The discussion 
above, and what will follow below, are important issues in decision theory 
and mathematical psychology. Analyzing how such preferences are made can 
enable us to understand and predict individual as well as group behavior. 
For example, how do we evaluate the decision making ability of a middle 
level corporate manager in order to determine if he is top management 
material? 

The discipline of utility theory provides the mechanism for quantifying 
preference. One reasonable measure, due to Luce [1956], is the notion of a 
semiorder. We assign a real number u(x) to each x € Vso that for all x and y 
in V, x is preferred over y if and only if u(x) is sufficiently larger than u(y). 
Formally, letting 6 > 0, a real-valued function u: V > R is called a semiorder 
utility function for a binary relation (V, P) if the following condition is 
satisfied: 


xyePoux)>uy)+o6 (x, ye V). (1) 


* Krantz, Luce, Suppes, and Tversky [1971, p. 17] present an argument against transitivity of 
preference. 
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Clearly, a relation P satisfying (1) is a partial ordering of V. The quantity 6 
represents the amount of fuzziness that must be filtered out. This enables us 
to be indifferent about events that differ by a minuscule amount. 

It is natural for us to ask the question, under what conditions does a 
preference relation (V, P) admit a semiorder utility function? 


Theorem 8.12 (Scott and Suppes [1958]). There exists a semiorder 
utility function for a binary relation (V, P) if and only if the following con- 
ditions hold: For all x, y,z,we V, 


(S1)  P is irreflexive; 
(S2) xye P and zwe P imply xwe P or zyeP. 
(S3) xyePand yze P imply xwe P or wze P. 


Such a relation P is called a semiorder. The conditions (S1)-(S3) constitute 
a set of axioms for a semiorder.* Proof of the necessity of these three con- 
ditions is straightforward and is given as Exercise 9. For the sufficiency half 
of the theorem, the reader is directed to the constructive proof of Rabinovitch 
[1977] or to the existence proofs of Scott [1964] and Suppes and Zinnes 
[1963]. 

Dean and Keller [1968] prove that the number of nonisomorphic semi- 
orders on an n-set is (")/(n + 1). In particular, they show that each iso- 
morphism class has a unique representative, called a normal natural partial 
order (NNPO), and they then demonstrate a one-to-one correspondence 
between (a) the NNPOs, (b) the normal subgroups of the upper triangular 
group of n x n matrices, and (c) the set of nondecreasing paths from (0, 0) to 
(n, n) on a Cartesian grid which never rises above the line x = y. Rabinovitch 
[1978] shows that every semiorder may be expressed as the intersection of at 
most three linear orders. No similar result holds for orders satisfying only 
(S1) and (S2), ie., interval orders. Jamison and Lau [1973] characterize the 
choice functions of semiorders. They also have a good table of references. 
For further investigation see the works of Fishburn [1970a—1970d, 1971, 
1973, 1975] and the excellent book by Roberts [1979c]. 

Our attention has thus far been focused on semiorders from the stand- 
point of the preference relation (V, P). We now investigate the indifference 
relation G = (V, E) of our semiorder (V, P). A number of characterizations 
are known for these undirected graphs. First, G is a special type of interval 
graph (Exercise 7). Second, a necessary condition easily follows from a 
semiorder utility function, namely, the existence of a real-valued function 
u on V satisfying 


xyeE<=|u(x) — u(y)| < 6 (x # y). 


* Unfortunately, the term semiorder was used in Ghouila-Houri [1962] and later in Berge 
[1973] in a different context. 
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We will see in the next theorem that this latter condition is also sufficient. 
The theorem provides a number of equivalent characterizations of indiffer- 
ence graphs, which are, simply stated, the class of cocomparability graphs of 
semiorders. Additional characterizations appear as Exercises 10 and 11. 


Theorem 8.13 (Roberts [1969]). Let G = (V, E) be an undirected graph. 
The following conditions are equivalent. 


(i) There exists a real-valued function u:V—R satisfying, for all 
distinct vertices x,y e€ V, 


xyeE < |u(x) — u(y)| < 1. 


(ii) There exists a semiorder (V, P) such that E = P + P7!. 
(iii) G is a comparability graph and every transitive orientation of 
G = (V,E) is a semiorder. 
(iv) Gis an interval graph containing no induced copy of K, 3. 
(v) Gis a proper interval graph. 
(vi) Gis a unit interval graph. 


Proof. (i) => (vi) Let u be a real-valued function satisfying 
xyeE<|u(x)—uy)[ <1 (#y). 


To each vertex x € V we associate the open interval I, = (u(x) — 4, u(x) + 4). 
Clearly, 


TOT, A D<|ux)—uy)|<1 (x # y). 


Therefore, the collection {7,},-, is a unit interval representation for the 
graph G. 


(vi) => (v) Since no unit interval can properly contain another unit 
interval, a unit interval representation for G will be proper. 

(v) => (iv) Let {J,},-y be a proper interval representation of G. Suppose 
G contains an induced subgraph G,, .,.,,,.,, isomorphic to K,, where 
{Z1,Z2,2Z3} is a stable set and y is adjacent to each z; (i = 1, 2, 3). If J,, is that 
interval among the intervals J,,, J,,, 1,, which lies entirely between the other 
two, then J, must properly contain I, ,, a contradiction. Thus, G can have no 
induced copy of K, 3. 

(iv) = (iii) (A. A. J. Marley [unpublished].) Since G is an interval graph, 
its complement G = (V, E) is a comparability graph. Let F be a transitive 
orientation of G. Using transitivity and Theorem 8.1 it is straightforward to 
show that F satisfies the axioms (S1) and (S2) of a semiorder (Exercise 7). 
We will show that (S3) also holds provided that G contains no induced copy 
of K, 3. Suppose xye F and yz e F, while xw¢ F and wz ¢ F. By transitivity 
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Figure 8.9. Solid edges are in the transitive orientation F of G = (V, E). Broken edges are 
inG = (V, €). 


of F, wx¢ F and zw¢ F, and wy¢F, yw¢ F, but xzeF (see Figure 8.9). 
Therefore, G,, ,, , is isomorphic to K, 3, a contradiction. 

(iii) => (ii) Immediate. 

(ii) > (i) ‘If (V, P) is a semiorder, then there exists a real-valued function 
u’: V— Rand a number 6 > 0 such that 


xyeP<u'(x) — u(y) = 6. 
Define u(x) = u'(x)/5. Since P + P~'! = E, clearly 
xyeE#|u(x)-—uQ)|<1  (#y). | 
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The intersection graphs obtained from collections of arcs on a circle are 
called circular-arc graphs. A circular-arc representation of an undirected 
graph G which fails to cover some point p on the circle will be topologically 
the same as an interval representation of G. Specifically, we can cut the circle 
at p and straighten it out to a line, the arcs becoming intervals. It is easy to 
see, therefore, that every interval graph is a circular-arc graph. The converse, 
however, is false. In fact, circular-arc graphs are, in general, not perfect 
graphs. For example, the chordless cycles C;, C7, Co, ... are circular-arc 
graphs (see Figure 8.10). 

As with interval graphs, it is immaterial whether we choose open arcs or 
closed arcs. The same class of intersection graphs will arise in either case 
(Exercise 13). We shall adopt the convention of open arcs. We call G a proper 
circular-arc graph if there exists a circular-arc representation for G in which 
no arc properly contains another. 

In Section 1.2 we discussed an application of circular-arc graphs to the 
traffic light phasing problem due to Stoffers [1968]. The astute reader may 
well be able to adapt some of the applications of interval graphs given in 
Section 8.4 to the more general class of circular-arc graphs. Stahl [1967] 
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Figure 8.10. A circular-arc representation of the nonperfect graph C,. 


suggests such a problem in genetics. Other relevant papers on applications 
of circular-arc graphs include Luce [1971], Hubert [1974], Tucker [1978], 
and Trotter and Moore [1979]. 

A characterization of circular-arc graphs due to Tucker, originally formu- 
lated in terms of the augmented adjacency matrix of a graph, is equivalent 
to the following. 


Theorem 8.14 (Tucker [1970b, 1971]). An undirected graph G = (V, E) 
is a circular-arc graph if and only if its vertices can be (circularly) indexed 
Vy, 0z,..-, V, SO that for all i and j 

ith 44,22, 0,€ Adj(v; 
either Vjp41, v, € Adj(u;) Q2) 


vv,eE=> . 
ae 2 Vjitir+ ++, 0; € Adj(v;). 


(If i <j, then 0j4,,..., 0; MeaNs 0;44,..., Up, V4, --.5 0;-) 


Proof. Let G have a circular-arc representation (open arcs). We may 
assume, without loss of generality, that no pair of arcs share a common 
endpoint (Exercise 14). Moving clockwise once around the circle from an 
arbitrary starting point, index the vertices according to the order in which the 
counterclockwise endpoints of their corresponding arcs occur. Let A; denote 
arc corresponding to v;. Clearly, v; is adjacent to v; if and only if the counter- 
clockwise endpoint of A, lies within A; or vice versa. In the former case, each 
of A;,1,..-, A; intersects A;, and in the latter case each of Aj44,..., A; 
intersects A ,. Thus (2) is satisfied. 

Conversely, let the vertices be indexed as required in (2). We will construct 
acircular-arc representation for G. Let p, be the kth hour marker on an n-hour 
clock. For each vertex v;, let v,,, be the first vertex in the cyclic sequence 
Vj+1> Vi+2>---, 0; Which is not adjacent to v;. Draw an open arc A; clockwise 
from p; tO p»,. By construction, A; intersects A; (i 4 j) if and only if either 
p;€ A; or p;€ A;. But also 


pj € A; 0;44,-.., 0; € Adj(v)). 
Therefore, by (2), v,v,€ E if and only if A; 0 A; # @. | 
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Theorem 8.14 gives us a method for recognizing circular-arc graphs and 
constructing a circular-arc representation. However, since the characteriza- 
tion is quantified over all permutations of the vertices, this method will be 
impractical for all but very small graphs. Tucker [1978] approaches the 
problem of trying to find a more efficient recognition algorithm. Details of a 
polynomial time algorithm will appear in Tucker [1979]. 

In view of Theorem 8.3 it is tempting to guess that a circular-arc graph is 
characterized by the circular I’s property of its clique matrix or some other 
matrix. Unfortunately, this is not the case. Three related theorems, however, 
are stated here without proof. 

We call G a Helly circular-arc graph if there exists a circular-arc represen- 
tation for G which satisfies the Helly property. 


Theorem 8.15 (Gavril [1974]). An undirected graph G is a Helly circular- 
arc graph if and only if its clique matrix has the circular 1’s property for 
columns. 


The augmented adjacency matrix of G is obtained from the adjacency matrix 
by adding 1’s along the main diagonal. 


Theorem 8.16 (Tucker [1970b, 1971]). An undirected graph G is a circu- 
lar-arc graph if its augmented adjacency matrix has the circular 1’s property 
for columns. 


Figure 8.11. A collection of arcs of a circle with representing sequence of endpoints 
o = fa, a, e, b, é, d, b, a, &, ¢]. 
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Theorem 8.17 (Tucker [1970b, 1971]). An undirected graph G is a proper 
circular-arc graph if and only if its augmented adjacency matrix has the 
circular 1’s property for columns and, for every permutation of the rows and 
columns that is a cyclic shift or inversion of their circular 1’s order, the last 1 
in the first column does not occur after the last 1 of the second column, 
excluding columns which are either all zeros or all ones. 


It is useful to regard a collection of arcs as a sequence o of its endpoints 
listed clockwise. Without loss of generality, we shall assume that no two arcs 
share a common endpoint (Exercise 14). In o the symbol x denotes the 
counterclockwise endpoint of arc A, and xX denotes its clockwise endpoint. 
For example, o = [a, d, e, 5, é, d, b, a, é, c] represents the collection of arcs in 
Figure 8.11. Any cyclic permutation of o would be an equally valid represen- 
tation. The manner in which two arcs A, and A, intersect is uniquely deter- 
mined by the pattern of the subsequence of o involving {x, xX, y,~}. Some 
examples are shown in Table 8.1. We shall utilize this model in proving the 
next theorem. 


Theorem 8.18. If G is a proper circular-arc graph, then G has a proper 
circular-arc representation in which no two arcs share a common endpoint 
and no two arcs together cover the entire circle (i.e., they do not intersect at 
both ends). 


Proof. The proof will be induction on the number of “circle covering” 
pairs of arcs. Let ow = {A,}.-y be a proper circular-arc representation of 
G = (V, E). We may assume that no two arcs share a common endpoint. 
Suppose A, and A, cover the entire circle, that is, they intersect in two 


Table 8.1 


Coding a family of arcs as a sequence of letters* 


Pattern of subsequence Interpretation 
[x, &, », J] A, NA, =O 
[9 ys x, X] A, c A, 
[x, y, & 9 A, and A, overlap at one end 
[x, 9, y, ¥] A, and A, overlap at both ends 


* Some examples of how the pattern of the subsequence 
of o involving {x, &, y, 9} determines the manner of inter- 
section of arcs A, and A,. Any cyclic permutation of a 
pattern leaves the interpretation unchanged. 
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disjoint subarcs. Let o be the sequence of endpoints of the arcs going clock- 
wise from the counterclockwise endpoint of A,. Thus, [a, 6, b, @] is the sub- 
sequence of o involving these letters, and o may be expressed as the con- 
catenation 0 = tp, where 


O = [005 B60, By ig Quek 
a a 
T p 


For any xe V, it is impossible for x and ¥ to appear in t in the order [x, x] 
since such an appearance would imply A, © A,, contradicting the supposi- 
tion that ./ is proper. 

Consider the new sequence o’ = t’p, where 1’ is obtained from t by listing 
those entries of t with hats followed by those without hats but preserving the 
relative order of each type. For any x, ye V, this unshuffling operation will 
leave unchanged the subsequence of o involving {x, x, y, )} unless either 
Lx, 7] or [y, X] is a subsequence of t. Since the cases are analogous, we assume 
that [x, f] is in t. We allow the possibility that x equals a or that y equals b. 
Now X may either precede x or follow Gin o, and y must fall between j and b, 
for otherwise would not be proper. This situation is depicted in Figure 8.12. 
Clearly, either [x, x, , y] or Lx, §, y, X] is a subsequence of o, indicating that 
A, and A, overlap at both ends. After the transformation from o or o’ occurs, 
these become, respectively, [%, f, x, y] or [, x, y, &], which correspond to 
arcs which properly overlap at only one end. 

Let ./’ be a set of arcs corresponding to o’. We have just shown that (i) 
some doubly intersecting arcs in .o are transformed into singly intersecting 
arcs in .’, and (ii) all other pairs in .o, including nonintersecting, singly 
intersecting, the remaining doubly intersecting, and properly contained (of 
which there were none) arcs, were left unchanged. Thus, ./' is a proper 
circular-arc representation of G with fewer circle covering pairs, and the 
theorem follows by induction. | 


This theorem was used in Section 1.2 to show that every proper circular-arc 
graph is also the graph of intersecting chords of a circle. (See also Chapter 11.) 
We conclude this section by presenting a polynomial-time algorithm which 
finds a maximum clique of a circular-arc graph. The algorithm appears in 


Ga lonteshek civ, Seeacnn x er ere 


ance 


Figure 8.12. A view of where in o the letters € and y could be hiding. 
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Gavril [1974] along with efficient solutions of the stable set problem and the 
clique cover problem for circular-arc graphs. The complexity of the coloring 
problem is unknown for these graphs. 

Let {A,},-y be a circular-arc representation of G = (V, E). Assume that 
no two arcs share an endpoint. Denote the counterclockwise and clockwise 
endpoints of A, by ¥ and X, respectively. For x € V, we define 


Y, = {ve VIE A,} + {x}, 
Z, = {ve V — Y,|X € Aj}. 


Each of Y, and Z, are complete sets, so the induced subgraph Gy +z, is the 
complement of a bipartite graph. Thus, finding a maximum clique of Gy, +7, 
can be done in polynomial time. 

Let K be a maximum clique of G. Choose a vertex x € K such that A, does 
not properly contain any arc A,, (we K). Hence, for every we K, x #w, 
either X € A,, or X € A,,. Therefore, K is a clique of Gy +7,. 

A maximum clique of G can be obtained as follows: For each x € V, con- 
struct and find a maximum clique K(x) of Gy_,z_; then select the largest 
among the K(x). 


EXERCISES* 


1. Discuss how interval graphs and the consecutive 1’s property could be 
applied to the following problem. Several psychological traits are to be 
examined in children. Assign an age period to each trait representing the 
natural order in the development process during which the trait is present. 
What traits would be appropriate for such a study? 

2. Let M be a symmetric (0, 1)-valued matrix. Prove that either M has the 
consecutive 1’s property for columns and rows or M has neither property. 
Prove the same result for circular 1’s. 

3. Prove that the clique matrix of an interval graph G = (V, E) has at most 
O(|V| + |E|) nonzero entries. Is this equally true for triangulated graphs 
(Fulkerson and Gross [1965])? 

4. Let % bea family of intervals on a line, and let k be the maximum possible 
number of pairwise disjoint intervals in .g. Prove that there exist k points on 
the line such that each interval contains at least one of these points (T. Gallai). 
5. Let Aand B be (0, 1)-valued matrices having the same shape. Prove that 
if A‘ A = B'B, then either both A and B have the consecutive 1’s property for 
columns or neither has it (Fulkerson and Gross [1965, Theorem 2.1]). A 


* Also review the exercises from Chapter 1. 
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stronger version of this is the following: If A7A = B'B and A has no sub- 
configuration of either of the forms below, then A = PB for some permutation 
matrix P 


111 0 0 0 
10 0 0 1 i 
0 1 OP 10 1 
0 0 1 1 1 0 


(Ryser [1969, Theorem 4.1 ]). 
6. Let P bea binary relation ona set V. A real-valued function u: V > R is 
called an ordinal utility function for (V, P) if 


xy € P <> u(x) > u(y). 


(a) Show that (V, P) admits an ordinal utility function if and only if P 
is irreflexive, antisymmetric, and satisfies the negative transitivity condition 
(transitive indifference), 


xy&P,yz¢éP=>xz¢ P. 


A (preference) relation satisfying the conditions in (a) is called a weak order 
in decision theory and a preorder in some mathematics literature. An ordinal 
utility function is like scores on an exam; this makes a weak ordering almost 
a total ordering (ties being allowed). Armstrong [1950] first observed that 
transitive indifference has important empirical shortcomings in a preference 
model.* To resolve these shortcomings, Luce [1956] introduced semiorders. 

(b) What is the structure of the indifference graphs of weak orders? 
7. Let G =(V, E) be an undirected graph. Prove that the following con- 
ditions are equivalent: 

(i) Gis an interval graph. 

(ii) G has a transitive orientation P satisfying axioms (S1) and (S2) of a 
semiorder. 

(iii) Every transitive orientation P of G satisfies (S1) and (S2). 
8. Consider the lexicographic ordering of the plane: A point (x, y) is strictly 
less than a point (x’, y’) if either x < x’ or both x = x’ and y < y’. Clearly for 
every pair of distinct points, one of them is strictly less than the other. Prove 
that there cannot exist a real-valued function f defined on the points of the 
plane which preserves the lexicographic ordering (ie., f(x, y) < f(x’, y) > 
(x, y) < (x’, y’)) (Debreu [1954]). 


* He wrote, 
The nontransitiveness of indifference must be recognized and explained on [sic] any theory of 
choice, and the only explanation that seems to work is based on the imperfect powers of 
discrimination of the human mind whereby inequalities become recognizable only when of 
sufficient magnitude [1950, p. 122]. 
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9. Prove the necessity half of the Scott-Suppes theorem. 

10. Prove that G is a proper interval graph if and only if its augmented 
adjacency matrix satisfies the consecutive 1’s property for columns (Roberts 
[1968 ]). (The augmented adjacency matrix of G is obtained from the adjacency 
matrix by adding 1’s along the main diagonal.) 

11. We say that vertices a and b are equivalent, denoted a ~ b, if their 
neighborhoods N(a) and N(b) are equal. A vertex x is called extreme if N(x) 
is complete (i.e., x is a simplicial vertex) and [a,b ¢ N(x), a ® x, b ® x] 
implies [Sz € N(a) 7 N(b), z€ N(x)] (see Figure 8.13). Finally, let G* be the 
quotient graph obtained from G by coalescing the vertices of each ~-equiva- 
lence class and preserving the adjacencies between classes. 


Figure 8.13. The shaded area is empty. 


Prove that the following conditions are equivalent to those in Theorem 8.13 
for an indifference graph G = (V, E). 

(vii) For every connected, induced subgraph H of G, either H* has 
exactly one vertex (i.e., H is complete) or H* has exactly two (nonadjacent) 
extreme vertices (Roberts [1969]). 

(viii) Gis triangulated and contains none of the graphs in Figure 8.14 as 
induced subgraph (Wegner [1967]). 


AAR 


Figure 8.14. Forbidden subgraphs. 


12. Let M = [m,,] be an incidence matrix and define the row sets A; and 
column sets B; as follows: 


A; = {ilmi = 1}, C= {ilm; = 1}. 


(a) Show that the following are equivalent. 
(i) Row intersection property: For every i, j, k, 


A; A;S A, or A; A, A; or A, A; S Aj. 


196 8. Interval Graphs 


(ii) Column intersection property: For every i, j, k, 
B,VB;S B, or BAB, SB; or BAB; SB; 


(Nakano [1973b]). 

(b) The matrix M is closed if B, 1 B; # SO implies B; U B; = B, for some 
column set B, of M. The closure cl(M) of M is defined by adding columns to 
M inductively: M® = M; M™ has column sets Bf" U BY for all BY") 
and B?~ of M“~” satisfying B&'—) 4 BY") 4 @. 

Prove that M has the consecutive 1’s property for columns if and only if 
cl(M) has the column intersection property (Nakano [1973a]). 

13. Let o# = {A,},., be a finite collection of closed arcs of a circle. Show 
that there exists another collection ./’ = {A‘},., of open arcs such that 

(i) A,N A, = Ge AL NA, = S, 
(ii) A, © Ay ALS A, 
14. Let ¢v = {A,}..., bea finite collection of open arcs of a circle. Show that 
there exists another collection ./’ = {A{},.-y of open arcs ofa circle satisfying 
the following for all x, ye V: 

(i) A,N A, = OAL NA, = O; 

(ii) A, GA, AL SA); 
(iii) no two arcs of ’ have a common endpoint. 
15. Let A be the n x m incidence matrix (vertices-versus-edges) of an 
undirected graph G. 

(a) Prove that G has a Hamiltonian circuit if and only if A has ann x n 
submatrix satisfying the circular 1’s property. 

(b) Prove that G has a Hamiltonian path if and only if A has an n x 

(n — 1) submatrix satisfying the consecutive 1’s property (Booth [1975]). 
16. Give an example of a circular-arc graph whose augmented adjacency 
matrix does not have the circular 1’s property. 
17. A graph G is a unit circular-arc graph if there exists a circular-arc 
representation for G in which every arc is of unit length. (The diameter of 
the circle is variable.) Verify that the graph in Figure 8.15 is a proper circular- 
arc graph but is not a unit circular-arc graph (Tucker [1974]). (Here we 
assume that all arcs are open or all arcs are closed.) 


(x, ye V). 


Figure 8.15. 
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18. Let G bea circular-arc graph. Show that 7(G) < 2m(G) (Tucker [1974]). 
19. A matrix M is said to have the unimodular property if every square 
submatrix of M has determinant equal to 0, + 1, or —1. (Every entry of sucha 
matrix is necessarily 0, +1, or —1.) Show that any (0, 1)-valued matrix 
satisfying the consecutive 1’s property is unimodular. 


Research Problem. Let % be a collection of intervals whose intersection 
graph is G, and let IC(.) denote the number of different sized intervals in ¥. 
Define the interval count of G, denoted IC(G), to be min{IC(¥)|.¥ is an 
interval representation of G}. Clearly, IC(G) = 1 iff G is a unit interval 
graph. Also, IC(K, 3) = 2. 

(i) For any k > 2, characterize all graphs G with IC(G) = k. 

(ii) Find good upper and lower bounds for IC(G). 
Leibowitz [1978] has constructed graphs of interval count k for all integers k. 
She has also found three classes of graphs with interval count 2, namely, trees 
that are interval graphs, interval graphs with a vertex whose removal leaves 
a unit interval graph, and threshold graphs. 


Research Problem. Define the interval number of G =(V, E), denoted 
IN(G), to be the minimum number t for which there exists a collection of 
sets @ = {U,},-y, where U, is the union of t (not necessarily disjoint) 
intervals on the real line, such that G is the intersection graph of %, ie. 
xyeE iff U. 0 U, # ©. Clearly, IN(G) = | iff Gis an interval graph. Also, 
any circular-are graph has interval number at most 2. 

G) For any k > 2, characterize the graphs G with IN(G) = 2. 

(ii) Calculate the interval numbers of some special classes of graphs. 

(iii) What are the best bounds for IN(G)? 
Trotter and Harary [1979] and Griggs and West [1979] have shown that 
the interval number of a tree is at most 2 and that 


IN(Kan,n) = [mn + 1)/(m + n)1. 


Griggs and West have also shown that IN(G) < [(6 + 1)/2], where 6 is the 
maximum degree of a vertex, with equality holding for triangle-free regular 
graphs. Griggs [1979] has proven that IN(G) < [(# + 1)/4] for all n-vertex 
graphs. 
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CHAPTER 9 


Superperfect Graphs 


1. Coloring Weighted Graphs 


In this chapter we turn our attention to a notion of perfection in weighted 
graphs. In the process, a more general type of coloring the vertices of a graph 
will be introduced, suggesting many interesting applications. The concept 
of superperfection, introduced in Section 2, is due to Alan Hoffman and 
Ellis Johnson. They were motivated by the shipbuilding problem (Applica- 
tion 9.1), and most of the early results are theirs. 

To each vertex x ofa graph G = (V, E) we associate a non-negative number 
w(x), and we define the weight of a subset S € V to be the quantity 

w(S) = 2 w(x). 
(Without loss of generality we may assume throughout that all weights are 
integral.) The pair (G; w) is called a weighted graph. The subset S will often 
be the vertices of a simple cycle or a clique or a stable set. 

An interval coloring of a weighted graph (G; w) maps each vertex x onto 
an (open) interval J, of the real line of width (or measure) w(x) such that 
adjacent vertices are mapped to disjoint intervals, that is, xy¢ EF implies 
I, 1, = @. Figure 9.1 shows two colorings of a weighted graph. The 
number of hues of a coloring (i.e., its total width) is defined to be |\), I,|. 
The interval chromatic number y(G; w) is the least number of hues needed to 
color the vertices with intervals. For the graph in Figure 9.1, ¥(G; w) = 10. 


Example!. If w(x) = 1 for every vertex xeV, then x(G;w) = x(G). 
That is, the notion of interval coloring reduces to the usual definition of 
coloring when al! weights are equal. 
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Figure 9.1. Two interval colorings of a weighted graph: (a) (G;); (b) a coloring of (G;w) 
using 12 hues; and (c) a coloring of (G; w) using 10 hues. 


Application 9.1 (The Shipbuilding Problem). In certain shipyards the 
sections of a ship are constructed on a dry dock, called the welding plane, 
according to a rigid time schedule. Each section s requires a certain width 
w(s) on the dock during construction. Can the sections be assigned space 
on a welding plane of total width k so that no spot is reserved for two sections 
at the same time? 

Let the sections be represented by the vertices of a graph G and connect 
two vertices if their corresponding sections have intersecting time intervals. 
Thus (G; w) is a weighted interval graph. An interval coloring of (G; w) will 
provide the assignment of the sections to spaces, of appropriate size, on the 
welding plane. This assignment will be consistent with the intersecting time 
restrictions. (The reader must be careful to distinguish between the time 
intervals which produced the edges of G and the coloring intervals which 
provide a solution to the assignment of space on the dock.) 


Remark 1. Larry Stockmeyer has shown that determining whether 
y(G; w) < kis an NP-complete problem, even if w is restricted to the values 1 
and 2 and G is an interval graph. It follows that the shipbuilding problem is 
NP-complete. 


Application 9.2 (The Banquet Problem). The menu for a banquet in- 
cludes a number of cooked dishes which must be prepared in advance. A dish 
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d must be baked for m(d) minutes at a temperature (not necessarily constant) 
between t,(d) and ¢t,(d). Unfortunately, there is only one oven. How can we 
schedule the dishes so that the total cooking time is minimized? 

Let G be the graph whose vertices represent dishes, with two vertices being 
connected if their corresponding dishes have disjoint temperature intervals 
(and therefore can never be in the oven at the same time). A y(G; m)-coloring* 
of (G; m) will provide a solution to the scheduling problem by assigning an 
appropriate time interval to each dish during which it is to be in the oven. 
The Helly property for (the temperature) intervals insures that there is always 
a common acceptable temperature for all dishes being simultaneously 
baked. (Our solution does not take into account the size limitation of the 
oven.) 


Remark 2. The banquet problem can be solved in polynomial time. This 
is particularly interesting in the context of Remark 1. The reason for the 
tractability here is that the graph obtained in the banquet problem is the 
complement of an interval graph. We will show in the next section that 
y(G; w) can be calculated in polynomial time whenever G is a comparability 
graph. 


Application 9.3 (Computer Storage Optimization). Most compilers 
maintain a one-to-one mapping between the variables in a program and 
their locations in storage. Therefore, in a tight storage situation, the program- 
mer may have to overlay storage by deliberately using the same variable for 
more than one purpose, much to the detriment of clarity and reliability of 
the program. Using the notion of interval coloring, Fabri [1979] has investi- 
gated freeing the programmer from the task of overlaying by having the 
processor perform all storage allocation decisions. Thus, we want an auto- 
matic construction of a many-to-one correspondence between the variables 
and storage which guarantees the integrity of the variables. It is assumed 
that the variables have differing size requirements (as with arrays). 

Let G be an undirected graph whose vertices correspond to the variables 
of a program. We connect two vertices v and u by an edge if and only if there 
is some node in the program flow graph at which v and u are simultaneously 
livet and thus enjoined from sharing storage. Associated with each vertex 
of G is a weight corresponding to the size of the variable. Since nonconflicting 
variables may overlay one another in storage, an interval coloring of G 
corresponds to a linear storage layout, and the interval chromatic number 
corresponds to the size of the optimum (i.e., smallest) such storage layout. 


* From this point on, we will use the term coloring to mean interval coloring whenever the 
context allows. 
+This can be determined by global data flow analysis. 
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We may regard an interval coloring in another manner. Associated with 
any such coloring of a weighted undirected graph G = (JV, E) is an implicit 
acyclic orientation F of G. This orientation is obtained by directing an edge 
toward the vertex whose coloring interval is to the right of the other, on the 
real line, that is, 


xyeF<Il, <I, (for all xye E). 


This suggests the following alternative definition of y(G; w). 


Proposition 9.1. Let (G; w) be a weighted undirected graph. Then 


(G3 w) = min( max 4) 
F 


BL 
where F is an acyclic orientation of G and yp is a path in F. 


Proof. Given F we define a coloring h of (G; w) in the same way that one 
usually constructs a height function in a partial order. For a sink x, let 
h(x) = (0, w(x)). Proceeding inductively, for a vertex y let t be the largest 
endpoint of the intervals corresponding to the sons of y, and define h(y) = 
(t,t + w(y)). Thus, h is a coloring and its number of hues equals max, w(y). 
This proves that y(G; w) < min,(max, w(j)). 

Conversely, a minimum coloring gives us an acyclic orientation F’ as 
mentioned above, and clearly y(G;w) > w(u) for any path yw in F’. This 
proves the reverse inequality, and hence equality holds. | 


2. Superperfection 


The clique number of a weighted graph (G; w) is defined as 
o(T;w) = max{w(K)|K is a clique of G}. 


As one might expect, w(G; w) < (G; w), which follows from Proposition 9.1. 
An undirected graph G is superperfect if for every non-negative weighting 


Figure 9.2. A superperfect graph. 
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Figure 9.3. 


w of the vertices w(G;w) = x(G;w). Equivalently, G is superperfect if for 
every Weighting w there exists an acyclic orientation F of G such that w(u) < 
w(K) for every path in F and some clique K of G. In particular, the weight 
of the “heaviest” clique in G will equal the weight of the “heaviest” path in F. 
Thus, we have two basic methods for demonstrating superperfection: pro- 
viding a suitable coloring or giving a suitable acyclic orientation. We shall 
illustrate these techniques on a few examples. 


Example 2. The graph in Figure 9.2 is superperfect. The heaviest clique 
is either (i) one of the two triangles or (ii) one of the three edges not contained 
in a triangle. Suppose (ii) is the case for some weighting w, and assume, 
without loss of generality, that {a, d} is the heaviest. Then w(b) + w(c) < 
w(d) and w(e) + w(f) < w(a), so that the coloring in Figure 9.3 will do. 
Otherwise, suppose (ii) is not the case, and assume that {d, e, f} is the heaviest 
clique. Therefore, w(a) + w(b) + w(c) < w(d) + w(e) + w(f) and, since (ii) 
has been ruled out, 


w(a) < we) + w(f), w(b) < w(d) + w(f), w(c) < w(d) + w(e). 


By cyclically permuting the vertices of each triangle if necessary, we may also 
assume that w(b) < w(d). If w(a) > w(f), then the coloring in Figure 9.4a 
gives a solution; otherwise Figure 9.4b works. Therefore, in every case, we 
have exhibited a coloring whose number of hues equals the weight of the 
heaviest clique. We conclude that the graph is superperfect. 


Example 3. An undirected graph is perfect if and only if for every (0, 1)- 
valued weighting w of the vertices w(G;w) = 7(G;w). Thus every super- 
perfect graph is a perfect graph. 


a e f f d e 
+--+ ——__t+—_r—_—_> 
> +-—_+—___? +> +——_— 

b c a a b ¢ 
(a) (b) 


Figure 9.4. 
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2 


Figure 9.5. G: not superperfect, 


Example 4. The graph G in Figure 9.5 is not superperfect since any 
acyclic orientation with the weighting shown would have a path of weight > 6. 
Its complement G (Figure 9.6), however is superperfect. 


Example 5. By extending a weighting w of X ¢ V to all of V, defining 
w(v) = 0 for all ve V —_X, it follows that each induced subgraph of a super- 
perfect graph is itself superperfect. 


Let F be a transitive orientation of a comparability graph G. By transi- 
tivity, every path in F is contained in a clique of G. So, in particular, for any 
weighting of the vertices of G, the weight of heaviest path in F equals the 
weight of the heaviest clique in G. This argument proves the following 
theorem. 


Theorem 9.2. A comparability graph is superperfect. 


Theorem 9.2 was first noted by Alan Hoffman, and he raised the question of 
the existence of superperfect graphs which are not comparability graphs. 
Such a graph was found by the author in 1974; it is the graph in Figure 9.2. 
We shall explore this question further in Sections 3 and 4. 

Theorem 9.2 has an algorithmic aspect as well. The interval chromatic 
number y(G;w) of a weighted comparability graph can be calculated in 
polynomial time. One must simply obtain a transitive orientation F, for 
which Algorithm 5.2 may be used, and then apply Algorithm 5.4 to find a 


Figure 9.6. G: superperfect. 
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maximum weighted clique. In fact, the optimal coloring may be calculated 
efficiently by a depth-first search procedure utilizing the method described in 
the proof of Proposition 9.1. 


3. An Infinite Class of Superperfect 
Noncomparability Graphs 


Before describing our class of graphs, we will prove the following useful 
lemma. 


Lemma 9.3. Let do,...,@,-; and bo,...,b,-, be sequences of real 
numbers such that 


n-1 n-1 
Ya < ¥ b,. 
i=0 i=0 


There exists a cyclic permutation z of {0, 1,...,n — 1} such that 


m 


Ya,< Yb, (m=0,1,...,0— 1). 
i=0 i=0 
Proof. Let c; = b; — a;. If each of the partial sums )'_p c; > 0 (m = 0, 
1,...,n — 1), then the result holds. Otherwise, let }'/_ 5 c; be the smallest of 
these partial sums (i.e, the most negative). 
Consider the permutation 2; =i+j+1(modn). For m=j + 1,..., 
n — | we have 


i=0 i=0 i=jt+1 
where, for m = 1,...,j, 
n-1 j n-t m n-1i 
0s Yae=¥Ne+ Mags Yat ¥ e, 
i=0 i=0 i=jt+i i=0 i=j+1 
thus proving the lemma. | 


Let n and k be arbitrary positive integers, n > k. Consider the undirected 
graph G,,, = (A + B, E), where 


)) A= {ao, a,,.-..,4,—,} iS a clique, 
Gi) B= {bo,b,,...,b,—,} is a clique, and 
(iil) a; is adjacent to bjs modmy) for j = 1, 2,...,k. 
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Figure 9.7. G,,,. 


Figure 9.7 illustrates these adjacencies. We remark here that G,,,_ is the 
same graph as C,,,, the complement of a chordless cycle of length 2n. The 
vertices of the cycle going around in order are [do, bp, 44, by,.-- An—15 Dn 1] 


Theorem 9.4 (Golumbic [1974]). For arbitrary integers n > k > 0, the 
graph G,, , is superperfect. 


Proof. Assume thatn > k > 0, for the other cases are trivial. Our method 
of showing superperfection has three steps. 


Step I. Assign an arbitrary weight to each vertex. 

Step II. Describe a particular acyclic orientation F. 

Step III. Show that every maximal path in F is either (i) contained in some 
clique, or (ii) has weight less than or equal to a path (already shown to be) 
in class (1). , 


We call F a superperfect orientation with respect to this weighting. 


Step I. We assign an arbitrary weight to each vertex. For simplicity, 
denote the weight of a; and b; by 4; and b,, respectively. We may assume that 
Ay + Gy +-+++4,-; <b) +b, +--+ + 5,_, by interchanging the sets A 
and B, if necessary. Furthermore, applying Lemma 9.3, we may assume that 
the vertices have been indexed so that the partial sums satisfy 

ayo t+ +4, Sb 4+-:-+6, (m=0,1,...,0— 1). 

Step II, Let us assign the acyclic orientation F of G,, , as follows: 


a,a;,b;b;e F (0<i<j<n-1), 
a;b;eF (0<i<j<min(n —- 1,i+4)), 
b,a;eF (O<i<k—-—lin-—k+i<sj<n-1) 
(see Figure 9.8). 
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Figure 9.8. Maximal paths in F. 


Step III. Any maximal path in F will start in a source node ap or Dg. 
(i) Consider a maximal path yp starting in by. Either p = [bo, b,...,b,-1], 
in which case it is contained in a clique, or, for some indices i and p,0O <i < 
k-1l<p<k-—-i, 

f= [B65 300y DAB « 6 dg spy Oy spaayees Pads 


(Obviously if p = 1, then there are no b’s at the end.) Now b,a;¢€E for 
t=0,...,iandj=n—k+i,...,n—1anda,_,b,-,4;€E forg <k —i 
and j < q + 1. Thus, yw is contained in a clique. 

(ii) Consider a maximal path v starting in a). Now v is of the form v = 
[ao,..-, 4, D,4 4, remainder] where b,, ; is the first b; in v. Since 


Ay t+ +4,< bo +--+ +5, 
the weight of v is no more than the weight of the path 
[bo,.--,0,, 0,44, remainder ], 


which is contained in a clique, concluding the proof of the theorem. | 


Corollary 9.5. The complement of an even-length cycle with no chords is 
superperfect. 


The next result shows that the graphs G,, , constitute a class of superperfect 
graphs distinct from the comparability graphs. 


Theorem 9.6. G,,, is not a comparability graph, for 1 < k <n — 2. 


Proof. Recall that an undirected graph is a comparability graph if and 
only if every closed path with no triangular chords has even length (see 
Theorem 5.27). However, 


[49, 41, dy 41, Bo, A415 os Des Ao, Aes Ag,+ ++, Aq, Dy, Ao] 


is such a closed path in G, , and has odd length. | 
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4. When Does Superperfect Equal Comparability? 


Figure 9.9 illustrates part of the world of superperfect graphs. We have 
shown in Section 3 that the superperfect graphs properly contain the com- 
parability graphs. This leads us to ask under what conditions these two classes 
coincide. In this section we shall give one answer to this question and we shall 
discuss some open problems. 

Féldes and Hammer [1977] have proved the following: 


Theorem 9.7. If G is a split graph, then G is a comparability graph if and 
only if G contains no induced subgraph isomorphic to H,, H,, or H; of 
Figure 9.10. 


Proof. The forward implication is immediate since none of the graphs 
in Figure 9.10 is a comparability graph. We shall show the reverse implica- 
tion. Let G be a split graph whose vertices are partitioned into a stable set 
X and a complete set Y. An edge of G is called pure if both its endpoints are 
in Y and called mixed otherwise. A vertex from X (resp. Y) is denoted by a 
subscripted lower-case x (resp. y). The key to the proof is the observation 
that a minimal [-chain (1e., one that does not properly contain another 
T-chain) wiil alternate between mixed and pure edges and will involve only 
two vertices of X. Assume that G contains no induced copy of H,, H,, or H;. 

Let y be a minimal I’-chain. Since no two pure edges are I-related, how 
many mixed edges may separate consecutive pure edges e, and e, in y? All 
such mixed edges will share a common vertex from Y, and hence they are 


Superperfect 


Figure 9.9. 
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H, Hy Ms 


Figure 9.10. 


IT-related to one another. Thus, if there were more than two, the chain y 
could be shortened, contradicting minimality. Suppose there are exactly 
two; then we have the following segment of », 


--foTe TAT ATA f-::, 


which corresponds to the diagram in Figure 9.11. By minimality of y, y, and 
y3 are adjacent, respectively, to x, and x,. If y, € Adj(x3) or y; € Adj(xo), 
which includes the possibility of x) and x3 coinciding, then G contains an 
induced copy of H,; otherwise, G contains a copy of H;. Therefore, y alternates 
between pure and mixed edges, as claimed. 

If G is not a comparability graph, then there exists a minimal [’-chain y 
from some mixed edge x, j, to its reversal, namely, 


Xo¥1 TV yoyr VT yaxy UT yays T x2¥3T yaya T yaxg 0 ---T Wy Xa, = JiXo- 


Now xo # x, and y» involves only these two vertices from X, since G has no 


induced copy of H,. Thus, x9 = x, = X4 =---andx, =x; =x; =---,and 
by the parity of the indices x,,, equals x, and not xg, a contradiction. This 
proves the theorem. | 


Figure 9.11. 
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One can easily verify that H,, H,, and H; are not superperfect (Exercise 1). 
From this observation we obtain a new result. 


Corollary 9.8. For split graphs, G is a comparability graph if and only 
if G is superperfect. 


Proof. Suppose G is not a comparability graph; then G contains one of the 
forbidden induced subgraphs of Figure 9.10. Since superperfection is a 
hereditary property, we deduce that G is not superperfect. The opposite 
implication is true for all graphs. 


The class of split graphs is very restrictive. We wonder how much it is 
possible to weaken the hypothesis of Corollary 9.8 and yet obtain the same 
conclusion. For example, all the superperfect noncomparability graphs of 
Section 3 were neither triangulated nor cotriangulated. Is it true or false that 
for triangulated (or cotriangulated) graphs G is a comparability graph if and 
only if G is superperfect? 


5. Composition of Superperfect Graphs 


Recall from Section 5.2 the definition of the composition of graphs. In this 
section we investigate how this operation affects superperfection. Let 
Go, G1,-.-, G, be undirected graphs, where Go has n vertices 04, V2,..., U,. 


Theorem 9.9. If Go, G,,..., G, are superperfect, then their composition 
G = Go[G,,..., G,] is superperfect; iLe., superperfection is preserved under 
composition. 


Proof. Let G; = (V;, E;) fori = 0,1,...,n be disjoint superperfect graphs, 
and let w be a weighting of V; + V, + --- + V,. (The vertices in Vy are not 
weighted since they will be replaced.) Suppose further that F; is a super- 
perfect orientation of G; with respect to w (restricted to G,) for each i = 0, 
1,...,n. We claim that F = F,[F,,..., F,] is a superperfect orientation of 
G with respect to w. 

Since each of the F; (i = 0,1,...,m) are acyclic, so is F. Let K; (i = 1,...,n) 
be a clique of G; whose weight w(K,) is greater than or equal to that of any 
path in F;. Define w‘(v,) = w(K,) for all v;€ Vo, and let Ky be a clique of Gp 
whose weight w(K) is greater than or equal to that of any path in Fy. Now 
any path win F,[F,,..., F,,] is of the form yp = [yj;,, pi, ---, Hi], where the 
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Figure 9.12. A chordless 5-cycle in (V4, Q). 


u,, are paths in distinct F;,,and the sequence of vertices [;,, 
path in Fy. Hence, we have the following inequalities: 


v;,] isa 


igatres 


w(u) = w(u;,) + +++ + wl) < w(K;,) + +++ + w(K;,) 
= w(u;,) +++ + w'(v,;,) 
< w(Ko). 


But the vertices of |_){K;|v;€ Ko} induce a clique K of Go[G,, ..., G,] whose 
weight w(K) equals w’(K,). Thus, we have shown that G is superperfect. J 


Example6. Let X,, be the set of positions of a k x k chessboard, and let 
Q be the binary relation defined on X, as follows: xy e€ Q iff a queen can be 
moved from position x to position y in a single chess move. 

Consider, for the moment, the graph (X,;, Q). Let x be the middle position 
and let X = X, — x. Notice that (X;, Q) is the composition of the single 
vertex x and the induced subgraph (X, Q,) with external factor K,. How- 
ever, (X, Qx) is the complement of a chordless 8-cycle and is therefore a 
superperfect graph. Hence, (X3, Q) is also a superperfect noncomparability 
graph. 

Clearly (X;,, Q) is an induced subgraph of (X;,, ,;, Q), so (X,, Q) is a non- 
comparability graph for all k > 3. Moreover, Figure 9.12 shows that (X4, Q) 
is not perfect since it contains a chordless 5-cycle. Thus, (X,, Q) is not perfect 
and hence not superperfect for k > 4. 


6. A Representation Using the Consecutive 1's 
Property 


We now relate the concept of superperfection to some ideas of linear 
programming. The material presented here is due to Alan J. Hoffman and 
Ellis L. Johnson. 
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Recall that a (0, 1)-valued matrix is said to have the consecutive I’s property 
(for columns) if the rows can be permuted so that all the 1’s in each column 
occur consecutively. Let M denote the stable sets-versus-vertices incidence 
matrix of an undirected graph G. 


Theorem 9.10. G is superperfect if and only if for every row vector w > 0 
the linear programming problem 


yM>w, y>0, (1a) 
minimize )° y;, (1b) 


t 


has an optimum (row vector) solution y such that 


the submatrix of M consisting of those rows S; with y,; # 0 has 
the consecutive l’s property. 


(2) 


Assume that the vertex set V is indexed v,, v2,..., v,, and let us interpret 
what the theorem says. 


Interpretation. Each stable set S; is assigned a plot on the real line of 
width y, for use only by its members. (Recall that no two members of S; will 
need this communal plot simultaneously.) 


Feasibility: By (1a) the sum of the widths of the plots available to a given 
vertex v; must be at least w,. 

Minimality: By (1b) the combined width of the plots is smallest possible. 
Consecutive I’s: By (2) the nonempty plots can be arranged so that those for 
each vertex are contiguous. 


Proof. From the above interpretation, it is clear that any y satisfying 
both (1a) and (2) gives a coloring of (G; w) of width ¥’ y;. The following 
converse also holds: 


For every coloring c of (G; w) there exists a vector y (to be con- 
structed below) satisfying (1a) and (2) such that )° y; equals the (3) 
width of c. 


Let c map V onto the interval from 0 to t. We may assume that c is left 
justified, that is, that no interval can be shifted to the left without disturbing 
the validity of c as an interval coloring. 

Divide each interval c(v;) into subintervals labeled with exactly those 
vertices assigned to that subinterval (see Figure 9.12). Each of these labels is 
some stable set. Suppose there are two subintervals, I, and I,, with the same 
label S;. If they are adjacent, then combine them into one larger subinterval. 
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If they are nonadjacent, there is a vertex v such that c(v) is wholly contained 
between J, and I, and whose left endpoint coincides with the right endpoint 
of I, (assume I, is to the left of J,). However, shifting c(v) to the left by the 
width of I, yields another coloring, contradicting left justification. Thus, we 
may assume that for each stable set S; there is at most one subinterval with 
label S;, and we define y; to equal the width of that subinterval if it exists and 
zero otherwise. Clearly, y satisfies (1a) and (2) and y y; equals the width of the 
coloring c. This proves claim (3). 
Consider the linear programming problem 


Mx < 1, x>0, 
ae (4) 

maximize ) w;x;. 

J 

By the Duality theorem, the optimum solutions of (1) and (4) are equal. 
Furthermore, if x is the characteristic vector of a clique of G, then x is a 
feasible solution to (4). Conversely, any integral feasible solution to (4) is the 
characteristic vector of a clique. Thus, an optimum solution f to (1) satisfies 


dF; = o(G; w). (5) 


We do not necessarily have equality in (5) since (4) may not have an optimum 
solution which is integral. (For example, consider the graph C,.) 

We are now ready to prove the theorem in one direction. Suppose that G is 
superperfect, and let w > 0 be given. Choose a coloring c of (G; w) of width 
«(G; w). By (3) we obtain a vector y satisfying (1a) and (2) with ) y; = 
«(G; w); and by (5), y is optimum. 

To prove the converse of the theorem, we need the following lemmas. 


If A is a (0, 1)-valued matrix whose columns have the consecutive 
l’s property, then A is totally unimodular (i.e., every subdetermi- (6) 
nant is 0, 1 or —1). 


Hence, if w is integral, then every optimum solution to (1) which satisfies 
(2) is integral. (See Hoffman and Kruskal [1956].) 


If for every integral w* > 0 (1) has an optimum solution which 
is integral, then for every w > 0 (4) has an optimum solution (7) 
which is integral.' (See Hoffman [1974] for analogous theorem.) 


Suppose that for all.w > 0 (1) has an optimum solution ¥ satisfying (2). 
Then y(G; w) = ); ¥;. By (6) and (7), there is an optimum solution x to (4) 
which is integral. But this optimum solution x is the characteristic vector of a 
clique of G, so w(G, w) = );, X;. Finally, by the duality of (1) and (4) we 
obtain y(G; w) = w(G; w). I 
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EXERCISES 


1. Using the technique of Example 5, prove that the graphs H,, H,, and 
H, of Figure 9.10 are not superperfect. 

2. Prove the following: If H is obtained from G by multiplication of vertices, 
then H is superperfect if and only if G is superperfect. 

3. Prove that the shipbuilding problem is NP-complete. 

4. Write a polynomial-time algorithm to solve the banquet problem. 
Analyze the complexity of your algorithm. 

5. Show that the bull’s head graph (Figure 1.14) is an interval graph which 
is not superperfect. 
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CHAPTER | O 


Threshold Graphs 


In this chapter we discuss a particularly simple technique for distinguishing 
between stable and nonstable subsets of vertices in a special class of graphs. 
The graphs that admit this technique, which involves assigning certain 
weights to the vertices, are called threshold graphs. Threshold graphs were 
introduced by Chvatal and Hammer [1973]. Their results form the basis for 
much of the next two sections. We begin by introducing the more general 
notion of threshold dimension. 


1. The Threshold Dimension 


Let V = {v,,v2,...,v,} be the vertex set of an undirected graph G. Any 
subset X ¢ V can be represented by its characteristic vector x = (X,,X2, 


..,X,), where for all i 
a= 1 if v,e X, 
‘O  if o€X. 


Thus, the subsets of vertices are in one-to-one correspondence with the 
corners of the unit hypercube in R” according to the coordinates of their 
characteristic vectors. 

Let us consider the collection of all stable sets of G. We ask the following: 
Is there a hyperplane that cuts n-space in half in such a way that on one side 
all corners of the hypercube (characteristic vectors) correspond to stable sets 
of G and on the other side all corners correspond to nonstable sets? Equiva- 
lently, can we distinguish which subsets of V are stable sets using a single 
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{ 
Figure 10.1. 


linear inequality? If the answer is affirmative, then the graph under con- 
sideration is a threshold graph. If not, we shall want to know how many 
inequalities are needed to distinguish between stable and nonstable sets. 


Example. Consider the graph in Figure 10.1. Its stable sets correspond 
to the solid corners of the unit 3-cube in Figure 10.2. The inequality x, + 
2x. + x3 < 2 is satisfied only by the characteristic vectors of the stable sets. 
Thus, a separating plane does exist, namely, x + 2y + z = 2. 

The threshold dimension 0@(G) of the graph G = (V, E) is defined to be the 


minimum number k of linear inequalities 


Ay 1X, + a12X2 tere t AinXn < th, 
: (1) 


QyyXy + AygX_ Fes + AynXy < ty, 


such that X is a stable set if and only if its characteristic vector x = (x,, 
Xz,..., X,) Satisfies (1). Regarding each inequality of (1) as a hyperplane in 
n-space, X is stable iff x lies on or within the “good” side of each of those k 
hyperplanes. Since G is finite, 0(G) is finite and well defined. 


“3 


Figure 10.2. The point p = (1, 1, 0) corresponds to the set {v, , v.}, which is not stable. 


1. The Threshold Dimension 221 


Remark. The only graphs G for which 6(G) = 0 are those having no 
edges. In this case, the empty set of constraints suffices. 


Let us first notice that without loss of generality, we may assume that all the 
numbers a;; and t; in (1) are non-negative integers. Suppose we are given a set 
of linear inequalities (1). Since the zero vector represents a stable set, we 
must have each t; > 0. Furthermore, any negative coefficient a,; can be 
changed to zero because for sets X not containing v; the sum COUNT;,(X), 
defined by 


COUNT(X) = Yi ay, = ¥ aipx,, 
vpeXx p=i1 

would remain unchanged, whereas for sets X containing v; this sum would be 
increased to COUNT(X — {v,}) which is <t; if and only if X is stable. 
Finally, since the graph is finite and the x; are integral, we can perturb the 
system by a small ¢ here and there to make all the numbers non-negative 
rationals. Then we multiply by the least common divisor in order to obtain 
integers. 

An undirected graph G = (V, E) whose threshold dimension 6(G) is <1 
is a threshold graph. Equivalently, G = (V, E) is threshold if there exists a 
threshold assignment [a; t] consisting of a labeling a of the vertices by non- 
negative integers and an integer threshold t such that 


X isstables> Ya(x)<t (XCV). (2) 


xeXxX 


Examples. The star graph K,_, is easily seen to be a threshold graph by 
assigning a(v) to be the degree of v and t = n, (Figure 10.3). Labeling by 
degree, however, does not always work. The labeling in Figure 10.4a fails to 
satisfy (2) for any value of t since there is a stable set of weight 7 and a non- 
stable set of weight 6. It is not a threshold assignment. On the other hand, the 


4 


Figure 10.3. The graph K, , and a threshold assignment with / = 6. 
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3 3 


(a) ; (b) 
Figure 10.4. (a) Degree labeling. (b) A threshold assignment for ¢ = 10. 


labeling in Figure 10.4b of the same graph is a threshold assignment for 
t = 10. There are graphs which are not threshold graphs. For example, the 
chordless cycle C,, with n > 4 is not threshold and neither is the path P, for 
n > 4 (Figure 10.5). 

It should also be noted that an induced subgraph of a threshold graph is a 
threshold graph. Therefore, any graph which contains an induced subgraph 
isomorphic to one of those in Figure 10.5 is not threshold. 

The threshold dimension @(G) of an arbitrary graph G can be defined in an 
alternate but equivalent manner using threshold graphs. Take @(G) to be the 
minimum number of threshold graphs needed to cover the edges of G, i.e., partial 
subgraphs of G, which are themselves threshold, and include every edge at 
least once. For example, 0(C,) = 2 since C, can be covered by two copies of 
K, 5. The formalities of proving the definitions equivalent are left to the 
reader (Exercise 13). However, one can easily see that each inequality of (1) 
corresponds to one threshold graph and vice versa, and taken together they 
determine the adjacencies of the graph. This idea of covering by threshold 
graphs can be used to prove the following theorem. Let «(G) denote the size 
of the largest stable set of G. 


Theorem 10.1 (Chvatal and Hammer [1973]). If Gis an undirected graph 
with n vertices, then 0(G) < n — o(G). Moreover, equality holds if (but not 
only if) G contains no triangle. 


Proof. Let X bea stable set of cardinality «(G). For each vertex v ¢ X let 
S, be the star graph with v at the center and having edges vu’ for each v’ 


Ww x w x w x 
2 y of y é y 


Figure 10.5. The graphs C,, P,, and 2K, are not threshold since any assignment would 
require the inequalities w+ y<t,w+z>t,x+2 <1, and x + y > ¢, which are incon- 
sistent. 
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adjacent to v in G. Thus, {S,|v¢ X} forms an edge covering of cardinality 
n — a(G), proving the first assertion. 

Since C,, and P,, are not threshold for m > 4 and since being threshold is a 
property inherited by induced subgraphs, it follows that any minimum cover 
{G,|i = 1,..., 0(G)} of a triangle-free graph G consists only of stars G,, 
whose center vertices we denote by u;. Moreover, any edge of G has at least 
one endpoint in U = {u,|i = 1,..., 0(G@)}, implying that V — U is stable 
and «(G) > |V — U| = n — &G). Combining this with the first assertion, 
we obtain «(G): = n — 0@(G) for triangle-free graphs. i 


Corollary 10.2. For the following graphs we have 


(i) AC,) = [n/2] (n> 3), 
(ii) O0(Kin,n) = MIN{m, n}, 
(iti) — O(P,) = |n/2]. 
Proof. Each of these graphs is triangle free, so the theorem provides the 
equalities. | 


As pointed out in Chvatal and Hammer [1977], the problem of computing 
@(G) is NP-complete in view of Poljak’s proof (Theorem 2.1) that computing 
a(G) for triangle-free graphs is NP-complete. We shall see, however, that 
deciding whether or not 0(G) = 1 can be done in linear time. 

Unfortunately, since 6(K,) = 1, the bound of the theorem is sometimes 
useless. However, the next result shows that it is the best possible. 


Corollary 10.3 (Chvatal and Hammer [1973]). For every & > 0 there 
exists a graph G with n vertices such that (1 — ¢)n < @(G). 


Proof. Erd6s [1961] has proved that for any positive integer N there is a 
triangle-free graph Gy with «(Gy) < N and n > c(N/log N)? vertices. (Here 
c is a positive constant independent of N.) Given ¢ > 0, choose N large 
enough so that ecN > (log N)? and consider the Erdés graph Gy. Since 
& > N(log N)?/cN? > N/n, it follows that (1 — cn <n — N <n — a(Gy) = 
A(Gy). 


2. Degree Partition of Threshold Graphs 


In this section we present a number of characterizations of threshold 
graphs. Let G = (V,E) be a threshold graph with threshold assignment 
[a; t]. The following properties are immediate: 

a(x) <t (xe V), (3) 
xyeEsa(x)+ay)>t (,yeV,x# y). (4) 
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A labeling satisfying (3) and (4) is not in general a threshold assignment since 
the sets being tested for stability are restricted to those of cardinality <2. 
However, condition (4) does imply the existence of a different labeling and 
threshold satisfying (2), as we shall prove in Theorem 10.4. For example, the 
labeling given in Figure 10.4a does satisfy (3) and (4) with t = 5, but it is nota 
threshold assignment. On the other hand, the labeling in Figure 10.4b is a 
threshold assignment for t = 10. 

We begin by defining the degree partition of an undirected graph G = 
(V, E) in which we associate vertices having the same degree. Let 0 < 6, < 
bd, <---<6,, <|V| be the degrees of the nonisolated vertices; the 6, are 
distinct and there may be many vertices of degree 6;. Define 69 = 0 and 
om+1 = |V| — 1. The degree partition of V is given by 


V2 Dee Dy ee De, 


where D;, is the set of all vertices of degree 6;. Only Do is possibly empty. 

The following theorem is due to Chvatal and Hammer [1973]. The 
equivalence of (i) and (11) was discovered independently by Henderson and 
Zalcstein [1977]. 


Theorem 10.4. Let G = (V, E) be an undirected graph with degree par- 
tition V = Dy + D, + --- + D,,. The following statements are equivalent: 


(i) Gisa threshold graph; 
(ii) there exists an integer labeling c of V and an integer (threshold) t 
such that for distinct vertices x and y, 


xyeEEsc(x) + cly) >t; 
(iii) for all distinct vertices x e D; and ye D,, 
xyeEsi+j>m; 
(iv) the recursions below are satisfied: 


6:4, = 6; +1D,,-; | (i = 0, 1,..., Lm/2] — 1). 
6; = 06:41 —|Dy-;| (i = m,m, — 1,..., |m/2] + 1). 

Before proving the theorem let us understand its significance. Statement 
(iii) says that the structure of the graph is entirely determined by the indices 
of the degree partition. The vertices contained in the first half of the partition 
cells form a stable set, while those contained in the later half of the partition 
cells from a complete set. Furthermore, the adjacencies possess a natural 
containment, as illustrated in Figure 10.6. Statement (iv) is most important 
computationally for it allows us to verify that we have a threshold graph by 
using purely arithmetic operations without making reference to edges or 
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Stable Clique 


Figure 10.6. The typical structure of a threshold graph. A line between cells D, and D, 
indicates that each vertex in D, is adjacent to each vertex of D,. Cell Dy contains all isolated 
vertices and may be empty. Cell D,,,,., only exists if m is odd. 


adjacency sets—-a very unusual situation in graph theory.* Since these 
recursive relations can be verified within O(n) computational steps for a 
graph with n vertices, we obtain the following. 


Corollary 10.5. Given only the degrees of the vertices of an undirected 
graph G, there is an algorithm which decides whether or not G is a threshold 
graph and which runs in time proportional to the number of vertices of G. 


Proof of this corollary is given as Exercise 7. 


Proof of Theorem 10.4. (i) = (ii) This is just Property (4). 

(ii) => (iii) The proof is by induction on the length of the degree partition. 
We may assume thatO <i<j<m. 

Let y be a vertex of largest label c(y). For any other vertex x, if x is adjacent 
to some vertex w (ie., x ¢ Do), then t < c(x) + c(w) < c(x) + c(y), implying 
that x is adjacent to y. Hence, ye D,,, 6,, = |V| — |Do| — 1 and each vertex 


* The reader will notice that the two sets of recursions actually use the same equation. They 
are stated separately to emphasize the method of calculation (69 and 6,,,, are known), and to 
indicate how they may be proved inductively. 
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in D,, is adjacent to all nonisolated vertices. This proves (iii) in the case 
j=m. 

Furthermore, the vertices of D, are adjacent only to those in D,,. For 
suppose 6, > |D,,|, then each vertex x e V — Dy would be adjacent to some 
vertex in V — D,,,; hence x would also be adjacent to z where z has the largest 
label in V — D,,. This forces z to be in D,,, a contradiction. Thus, 6, = |D,,|. 

Finally, let V’ = V— D) —D,, and consider the induced subgraph 
Gy. = (V’, Ey.) which also satisfies (ii). Since its degree partition V’ = 
D, +---+D,,-, is shorter by 2 than our original, the induction hypothesis 
proves the claim for j < m. 

(ili) > (iv) After some reflection (iv) is seen simply as a restatement of 
(iii). 

(iv) = (i) We shall assign an integer label a; to each x € D; such that the 
sum of the labels of the vertices in X¥ ¢ Vis less than or equal to a designated 
integer t if and only if X is a stable set. Now Dy + --- + Diny2, 18 Stable, and if 
X is a stable set containing a vertex ye D; with j > |m/2], then X — yc 
Do fee yh Din -j> 

The reader may verify that the following labeling is a threshold assign- 
ment. (He should do the arithmetic base | V |.) 

a= iV (i = 0, 1,..., Lm/2)J), 
t= 2| V |imi2i+ - 
t+1—|yyjr st} Gi = Lm/2] + 1,..-., m). | 


aj 


Remark. Orlin [1977] has given a construction of the unique integral 
threshold assignment which minimizes the threshold t. 


Notice that almost the mirror image of Figure 10.6 will appear if we 
replace edges by nonedges in that illustration. This is not surprising in light 
of the following corollary. 


Corollary 10.6. The complement of a threshold graph is a threshold 
graph. 


Proof. Assume that a labeling satisfying condition (ii) is given. The 
labeling c(x) = t — c(x) (for all x € V) with the threshold ¢ = t — 1 satisfies 
(ii) for the complement since 

xy€E<0 <t — c(x) — c(y) 
<>t < C(x) + Cy) 
<>f < C(x) + Cy). | 

From this corollary we conclude that a graph with n vertices is threshold 

if and only if there exists a hyperplane in R" separating the characteristic 
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vectors of the complete sets of vertices from the characteristic vectors of the 
noncomplete sets. An alternative proof of Corollary 10.6 follows from the 
next result. 


Theorem 10.7 (Chvatal and Hammer [1973]). A graph is threshold if 
and only if it has no induced subgraph isomorphic to 2K,,P4, or C4. 


Proof. The graphs 2K,, P,, and C, are not threshold graphs (Figure 
10.4), hence no threshold graph can contain one of them. Conversely, 
suppose G = (V, E) is not threshold, then there exists a subset X ¢ V with 
|X| > 4 such that @ # Adj(x) mn X # X — {x} for each x eX. (This is a 
straightforward consequence of Theorem 10.4; see Exercise 3.) Choose 
x, € X to have the smallest degree in G, and pick x,, x3 € X so that xx, EE 
but x,x3; ¢E. Since |Adj(x,;) 9 X| < |Adj(x3) 0 X| there exists an x,€ X 
such that x,x,¢E but x,x4 ¢ E. Thus, the set {x,, x,, x3, x4} induces one 
of the three forbidden graphs 2K,, P,, or C,, which proves the theorem. Jf 


Benzaken and Hammer [1978] have studied an analogous threshold prob- 
lem for absorbent (or dominating) sets. A subset X of vertices is absorbent 
if every vertex not in X is adjacent to some member of X. The class of graphs 
obtained properly contains the threshold graphs. They give a number of 
characterizations of this class. 


3. A Characterization Using Permutations 


Where does a threshold graph G fit into the world of perfect graphs? First 
of all, G is a split graph since its vertices can be partitioned into a stable set 
and a complete set; the edges between these sets are structured in a manner 
that has already been described. Secondly, the edges of G can be transitively 
oriented; let the vertices of G be numbered according to ascending degree 
and orient each edge toward its larger numbered endpoint. By Corollary 
10.6, the complement G can also be transitively oriented, so G is a special 
kind of permutation graph. In the nomenclature of Section 6.1, every thresh- 
old graph is a triangulated—cotriangulated—comparability-cocomparability 
graph, or symbolically, 


THRESHOLD <« TA TACOC. 


This inclusion is proper as demonstrated by the graph P,. 
Let us characterize threshold graphs in the context of permutation graphs. 
Let x be a permutation of the numbers {1, 2,..., n}. In Chapter 7 we 
defined the graph of x, denoted by G[z], to have vertices numbered v,, 
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V2,..-, U,, With v; and v, adjacent if and only if (i — j)(a; * — 2j') < 0. For 
example, writing 7 as the sequence 7,7, --- 7, we see that G[1,2,...,n] has 
no edges whereas G[n, n — 1,..., 1] is the complete graph. Recall that the 
graphs G[z] and G[x*] are complementary, where x’ denotes z written in 
reversed sequential order. Finally, an undirected graph G is a permutation 
graph if it is isomorphic to G[x] for some z. 

Let o and t be two sequences over some alphabet. The shuffle product is 
defined as follows: 


Out = {6,71 °°-O,% |6 =O,---o, and tT=1,--- tf. 


Here the o; and t; are subsequences, k ranges over all integers, and juxta- 
position means concatenation. The notion of shuffle product appears in 
automata theory (see Eilenberg [1974]). 


Theorem 10.8 (Golumbic [1978a]). The threshold graphs are precisely 
those permutation graphs corresponding to sequences contained in 


{1,2,...,pJwfn,n —- 1,...,p + 1], (5) 
where p and n are positive integers and ws denotes shuffle product. 


Proof. Let G = (V, E) be a given threshold graph with degree partition 
V=Do+D,+---+D,. Let s;= Yi-9|D,| and rename the vertices 
Vj, V2,-.-, ¥, Such that deg v; < deg v;impliesi < j. We define a permutation 
n as follows: 


> ita if |Do| >0, 
ar: empty sequence otherwise; 


JL sis ise ghd for 1<i<\|m/2], 
~ Ufs;s-..,1 + 5)41] for Lm/2{<i<m: 


Th = VoYmY1¥m—-172¥m—2°** Yim/2)- 
Note that z is of the form (5), and that 


v, € Dy <> Spy < ZS Sy ZEYy. (6) 


We will show that G = G[z]. 

Choose vertices v, € D; and v, ¢ D;; we may assume that x < y and hence, 
by construction, i < j. By (6), v, and v, are adjacent in G[z] if and only if y 
appears to the left of x in z. This will occur if and only if either (1) i < | m/2] 
and y;, is strictly to the left of y; or (ii) |m/2| < i < j. But conditions (i) and 
(ii) together are equivalent with i + j > m. Hence, by Theorem 10.4(iii), v, 
and v, are adjacent in G[z] if and only if vv, € E, proving that G = G[z]. 

Conversely, any permutation of the form (5) yields a threshold graph. J 
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Teng and Liu [1978] use the shuffle product for the integration of several 
logically independent and concurrently operating transmission grammars. 
Transition grammars describe the rules, or protocols, which regulate the 
interactions between the attached entities in a computer network to ensure 
that they proceed in an orderly fashion. 


4. An Application to Synchronizing Parallel 
Processes 


Threshold graphs were rediscovered and studied by others, including 
Henderson and Zalcstein [1977]; they are responsible for the application 
presented here. See also Vantilborgh and van Lamsweede [1972]. 

A hypergraph H = (S, &) consisting of a vertex set S and a hyperedge 
collection & of subsets of S, is called a threshold hypergraph if there exists a 
non-negative integer labeling c of S and an integer threshold t such that for all 
xcS, 


X contains no hyperedge <= Y c(x) < t. 


xeX 


As before, we call the pair [c; t] a threshold assignment for H. 

Unlike the special case when H is a graph for which many results are 
known, the problem of characterizing threshold hypergraphs is unsolved and 
appears to be quite difficult. Nevertheless, threshold graphs and hypergraphs 
can be useful in an application to computing which we will now present. 

Consider a set of computer programs Y = {P;} to be run in parallel. 
(Some of the P; might actually be subroutines of larger programs.) Because of 
overall memory constraints or common memory location requirements some 
conflict may arise when a certain subset # of FY is not able to run simul- 
taneously. Let & denote the collection of all such forbidden #’. Hence, the 
programs in X © ¥ can be run together without conflict if and only if X 
contains no member of @. 

When (9, &) is a threshold hypergraph a particularly simple programming 
technique can be applied to let the computer prevent conflicts automatically 
and control the traffic of programs running and waiting. Let [c;t] be a 
threshold assignment for (, &) and denote c; = c(P;). The technique is as 
follows. 


(1) Precede each program P;, with a call to procedure P(s, c;). 
(2) Follow each program P; with a call to procedure V(s, c;). 
(3) Initialize a new global variable s with the value t. 
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procedure P(s, c): procedure (s, c): 
ifs > c then Seste 
Ses o return 
enter P. 
else 
call again 
return 
Figure 10.7. Subroutine P requests permission to begin and subroutine V informs the 


traffic controller that the program is finished. Variable s records how much “room” is currently 
available. 


(See Figure 10.7.) The variable s, called a semaphore, never allows the sum 
of the c; for those programs currently running to exceed t. The number c¢; 
resembles the space required to do P;. Every time we wish to execute a 
routine P;, the procedure P checks whether or not there is sufficient space 
(ie., is s > c;). If so, we reduce s by c; and begin; if not, then we wait (in a 
queue) until there is enough space. When we finish P; the procedure V re- 
leases c,; units of space. 


Example 1. Givena set of programs {P;} such that at most 12 of them can 
be executed simultaneously, assign ¢ = 12 and c(P;) = 1 for each i. 


Example 2. Let 7 consist of three types of processes: the readers R,,..., 
R,; the writers W,,..., W,; and the mathematicians M,,..., M,,. Assume 
that we may execute simultaneously either at most one mathematician plus 
an unlimited number of readers or at most one writer.* This problem has the 
threshold assignment 


c(R;) = 1 (i= 1,...,n), 

c((M,)=r+1 VG =1,...,m), 

c(W,) = 2r +1 (k = 1,..., w), 
t=2r+1. 


Although there is no accurate graph theoretic formulation for Example 1, 
Example 2 can be viewed as a graph G with edges connecting the readers with 
the writers, the mathematicians with each other and the writers, and the 
writers with everyone. In this case the stable sets of G correspond to the 
subsets which can be executed simultaneously. 


Example 3. If we add some bureaucrats B,,..., B, to Example 2 who 
can work with writers but cannot work with mathematicians, then the system 
no longer has a threshold assignment. 


* If someone is writing on the system, no one else may have access since changes are being 
made. Otherwise, as many readers can work as want, but only one mathematician can work 
because there is only one calculator and he needs a calculator. 
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Finally, suppose we have a system with threshold dimension k. We can 
proceed similarly using P’s and V’s except that k semaphores will be needed. 
One semaphore handles each inequality (or labeling), and a segment P; can 
be entered if and only if there is sufficient resource according to each of the k 
semaphores. 


EXERCISES 


1. Prove that 0(G) <n+ 1 — w(G), where @(G) and a(G) denote the 
threshold dimension of G and the size of the largest clique of G, respectively. 
2. Show that 6(H) < 0(G) for any induced subgraph H of G. 

3. Prove the following: G = (V, E) is a threshold graph if and only if for 
each subset X < V there exists a vertex x € X such that Adj(x) 7 X = @ or 
Adj(x) nm X = X — {x} (ie. x is adjacent to all the vertices of X — {x} or to 
none of them; Chvatal and Hammer [1973].) 

4. Show that the following procedure will recognize threshold graphs. 
What is its complexity? 


Boolean procedure THRESHOLD(G): 
begin 
while the edge set is nonempty do 
begin 
delete all isolated vertices; 
if there is a vertex x adjacent to all remaining vertices then delete x; 
else 
return false; 
end 
return true; 
end 


5. Prove the following: A graph G = (V, E) is threshold if and only if its 
vertices can be ordered and partitioned into a stable set X = {x,,X2,..., Xs} 
and a complete set Y = {y,,..., y,} such that 


Xi VjEE > xp yp EE @2i j >). 


6. Prove that a threshold graph G with degree partition V = Dy) + D, +--- 
+ D,, has a Hamiltonian circuit if and only if the following relations are 
satisfied : 


|Do| = 0, 
k m 
YIDI< YL [Dl &=1,2,..., Lm - 1/2), 
i=l jamtin-k 
m/2 m 
YLIDI< \ [Dl Gf mis even). 
i=l j=m/2+1 


Show how one may obtain the Hamiltonian circuit. 
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7. Let H have vertices 1, 2,...,n and let DEG (i) equal the degree of vertex i. 
Write an algorithm which verifies the recurrence relations in Theorem 
10.4(iv). Prove that your algorithm runs in O(n) time. 

8. Calculate the threshold dimension for the graphs in Figure 10.8 thus 
showing that 6(G) is not in general equal to 6(G) for nonthreshold graphs. 


Figure 10.8. 


9. Find necessary and sufficient conditions for a sequence [a,, a2,..., a,; ¢] 
to be a threshold assignment for some threshold graph. 
10. Prove that the number of mutually nonisomorphic n-vertex threshold 
graphs is 2"~!. 
11. Prove that G is a threshold graph if and only if equality holds in each 
of the Erdés—Gallai inequalities (see Section 6.3) (Hammer, Ibaraki, and 
Simeone [1978]). 
12. Verify that the labeling given at the end of the proof of Theorem 10.4 
is a threshold assignment. 
13. Let 6'(G) denote the smallest integer k for which there exist partial 
subgraphs (V,, E,), (V2, E2),...,(V,, E,) of G = (V, E) satisfying E = E, vu 
E,U---UE,, where each (V;, E;) is a threshold graph. Prove that @’(G) 
equals the threshold dimension 0(G) of G. (Note: You may assume V; = V 
for each i. Why?) 
14. Let G be a threshold graph whose vertices are numbered according to 
increasing degree. Prove that the orientation obtained by directing each 
edge of G toward its larger numbered endpoint is transitive. 
15. Let X bea set of propositions and let Y be a set of subjects in a psycho- 
logical experiment. A subject either agrees or disagrees with a proposition. 
A Guttman scale is a linear ordering of X U Y such that a subject agrees 
with all items following it and disagrees with all items preceding it. Let G 
be an undirected graph with vertex set X U Yconstructed as follows: X forms 
a stable set; Y forms a clique; subject y is adjacent to proposition x if and 
only if subject y agrees with proposition x. The following are from Leibowitz 
[1978]: 

(i) Prove that there exists a Guttman scale for X u Y if and only if G 
is a threshold graph. 
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(ii) Give an algorithm to construct a Guttman scale. For a discussion 
of Guttman scales, see Coombs [1964]. 
16. Prove that every threshold graph has an interval representation using 
intervals of at most two different lengths (Leibowitz [1978]). 
17. Let m(G) denote the number of maximal cliques of an undirected graph 
G and let a(G) be the stability number. Clearly, 


a(G) < m(G), 


since there must be «(G) distinct cliques containing the members of a maxi- 
mum stable set. 
An undirected graph G = (V, E) is said to be trivially perfect if for each 
A c V,the induced subgraph G, of G satisfies o(G,) = m(G 4). This name was 
chosen since it is trivial to show that such a graph is perfect. Prove the 
following (Golumbic [1978b]): 
qa) A graph G = (¥V, E) is trivially perfect if and only if it contains no 
induced subgraph isomorphic to C, or P,. 
(ii) A connected graph is trivially perfect if and only if it is a com- 
parability graph whose Hasse diagram is a rooted tree. 
(iii) Gand G are both trivially perfect iff G is a threshold graph. 


Research Problem. Characterize the graphs of threshold dimension 2. 


Research Problem. Let S be a finite set and let & be a collection of subsets 
of S each of size r. The pair H = (S, &) is usually called an r-regular hyper- 
graph. If r = 2, then H is just an undirected graph. Consider the following 
properties: 

(T,) There exists a (positive integer) labeling c of S and an (integer) 
threshold t such that, for all subsets X ¢ S, 


X contains no member of & <> Y c(x) < t. 
xeX 


(T,) There exists a (positive integer) labeling c’ of S and an (integer) 
threshold ¢’ such that for all subsets A ¢ S of size r, 


Ae&<> Vi c(x) >t. 
xeA 

(T;) For x,y eS define x > y if x can replace y in any hyperedge (mem- 
ber) of &. That is, x > y if lye Ae and x¢ A] imply A — {y} + {x} e@. 
Then, for all x, ye S, either x = y or y > x or both. 

Clearly (T,) = (T,) => (13). Either prove or disprove the reverse implica- 
tions. [We know they are both true when r = 2. Perhaps a proof for r = 3 
would generalize to arbitrary r.] 
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CHAPTER | | 


Not So Perfect Graphs 


1. Sorting a Permutation Using Stacks in Parallel 


Let x be a permutation of the numbers {1, 2,..., 1}, which we will regard 
as the sequence x = [7,,72,...,2,]. We would like to sort z into natural 
order using a system of stacks arranged in parallel, illustrated in Figure 11.1. 
Initially, the permutation sits on the input queue. Two types of moves are 
allowed: (i) moving the number at the head of the input queue onto the top 
of one of the stacks or (ii) moving a number from the top of a stack to the tail 
of the output queue. A successful sorting is accomplished by transferring all 
numbers to the output queue in the order [1, 2,..., n] by repeatedly applying 
(i) and/or (ii). 

Given a sufficient number of stacks, any permutation can be sorted in this 
manner. But when can a permutation x be sorted using a system of only m 
stacks in parallel? For example, the sequence x = [3, 5, 4, 1, 6,2] requires 
three stacks, since the numbers 3, 5, and 6 must be stored on different stacks 
until 2 has reached the output queue. The observation that 3, 5, and 6 occur 
in their natural order but are followed by the smaller number 2 is the key to 
converting this sorting problem into a graph coloring problem. 

Let H[x] be the undirected graph having vertices {1, 2,...,n} with j and 


k adjacent if there exists an i such that 
i<j<k and Mp Te es 
235 
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Figure 11.1. A system of stacks in parallel. 


We can read z; ' = (x7 '); as “the position of i in z.” An example of this 


construction is given in Figure 11.2. We call H[7] the stack sorting graph 
of x. It is a straightforward exercise to show the following: 


m can be sorted in a system of m stacks in parallel if and only if the chro- 
matic number of H[z] is at most m. 


One possible application of this sorting technique is in rearranging the 
railroad cars of a train in a switching yard (see Knuth [1969, Section 2.2.1; 
1973, pp. 169-170], Even and Itai [1971], and Tarjan [1972]). 

Let # be the collection of all graphs G such that G is isomorphic to H[z] 
for some permutation z. Very little is known about the class #. There have 
been no efficient recognition or coloring algorithms produced for the graphs 
in # which are in general not perfect graphs. Neither is there a good graph 
theoretic characterization. Our reason for introducing the class ¥ is to show 
an equivalence between # and another class of graphs which has frustrated 
mathematicians for some years, namely, the circle graphs. 


Figure 11.2. The graph (3, 5, 4, 1, 6, 2]. 
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2. Intersecting Chords of a Circle 


An undirected graph G is called a circle graph if it is isomorphic to the 
intersection graph of a finite collection of chords of a circle (see Figure 11.3). 
Without loss of generality, we may assume that no two chords share a 
common endpoint. 


Theorem 11.1 (Even and Itai [1971]). An undirected graph G is a graph 
of intersecting chords of a circle if and only 


G — {all isolated vertices} = H[n] — {all isolated vertices} 


for some permutation z. 

This theorem will be proved constructively by demonstrating two tech- 
niques, Algorithms 11.1 and 11.2, whose correctness will be shown in 
Propositions 11.2 and 11.3, respectively. The algorithms transform one 
representation into the other. 


Remark1i. The subtraction of isolated vertices in the theorem is required. 
Two intersecting chords would give the complete graph on two vertices, 
whereas any graph H[z] which has an edge must have at least three vertices. 


Remark 2. From the point of view of coloring, covering by cliques, and 
finding a maximum stable set or maximum clique, isolated vertices neither 
add to nor subtract from the essential complexity of the problem. 


Remark3. A circle with intersecting chords enables us to generalize the 
notion of a matching diagram which we encountered in Section 7.4. Further- 
more, sorting a permutation using stacks in parallel is very much like the 
problem of sorting a permutation using parallel queues discussed in Section 


Figure 11.3. A set of chords and its intersection graph. 
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7.5. The remarkable feature of Theorem 11.1 is that the equivalence estab- 
lished in Chapter 7 between permutation graphs and sorting in parallel 
queues extends to an equivalence between circle graphs and sorting in 
parallel stacks. 


Algorithm 11.1. Constructing a circle with chords from a permutation. 


Input: A permutation x of the numbers 1, 2,..., n. 
Output: A circle @ with n chords. 
Method: The algorithm is as follows: 


1. DRAW A CIRCLE. Label nodes 2,, 22, ..., 2, in a clockwise manner, 
2. We go once around the circle clockwise starting just prior to 7, . 

3. fori | tondo 

4. if you have not passed by node i 

5. then SKIP clockwise to /; 

6 Draw another node i immediately clockwise (but before the next node); 
7, next /; 

8. DRAW chords matching the pairs of numbers. 


Example 11.1. We apply Algorithm 11.1 to the permutation 2 = 
[2, 9, 4, 6, 7, 1, 3,8, 5]. The instructions executed by the algorithm are 
given in Figure 11.4 along with the stack sorting graph H[x] and the initial 
and final configurations for the circle @ of chords. 


Proposition 11.2. Given a permutation x, Algorithm 11.1 constructs a 
set of chords of a circle whose intersection graph is isomorphic to H[z]. 


Proof. Suppose j and k are adjacent in H[x] and assume j < k. Then 
there is an i such that i <j < k and 2;' < 2, ' < 2;', which implies that 
after the ith iteration of Algorithm 11.1 j and k have already been passed 


OO ® 


Initial configuration Final configuration H[2,9,4,6, 7,4, 3,8, 5] 


Figure 11.4. Algorithm 11.1 applied to the permutation = [2, 9, 4, 6, 7, 1, 3, 8, 5]. The 
instructions executed are as follows. 
Skip to 1; draw a 1. Draw a 2. Skip to 3; draw a 3. Draw a 4. Skip to 5; draw a 5. Draw 6-9. 
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over. Hence we shall write the new j before the new &, and their chords wiil 
therefore intersect. 

Conversely, suppose two chords intersect and, reading clockwise around 
the circle from the starting point, their endpoints are labeled j, k, j, k.* Thus 
j<kandx;' <x, '. Since in the jth iteration we had already passed the 
first k, there must be an i, i < j, such that during the ith iteration we skipped 
over k to the first occurrence of i. Thus, 7, ' < 2, ', so j and k are adjacent 
in H[r]. | 


Algorithm 11.2. Constructing a permutation from a circle with chords. 


Input: A circle @ with chords. 
Output: A permutation x of the numbers 1, 2,..., n. 
Method: The algorithm is as follows: 


1. Pick a number a (a lucky choice will eliminate renumbering later): 
2. Initialize: i - n; pick a starting point (not an endpoint of a chord); 
3. for once around the circle going counterclockwise do 


begin 
4. if next endpoint p is unlabeled 
then 
5. label it i; label its opposite endpoint /’; 
6. decrement: i — i — 1; 
else 


7 create a dummy endpoint on the circle just preceding p; 
8 label the dummy /’; 
9, decrement: i <— i — 1; 
0 skip to just prior to the next unlabeled endpoint; 
end 
11, renumber everything so that the smallest label is 1 (by subtracting the final value of i from 
each); 


12. print the sequence of primed numbers running clockwise from the starting point and call 
them 7,, 22, ..., respectively; 


Example 11.2. Applying Algorithm 11.2 to the circle in Figure 11.5, 
we obtain the permutation a = [7, 4, 2, 10, 6, 1, 8, 3, 9, 5]. The instructions 
executed by the algorithm and the final (labeled) configuration for @ are 
also given. 


Proposition 11.3. Given a set of chords of a circle , Algorithm 11.2 finds 
a permutation x such that the intersection graph of @ is isomorphic to 
H[x] — {some isolated vertices}. 


* The second occurrences of j and k were created from the index of the loop, which is in- 
creasing. 
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srort 


C: Initial configuration Finai configuration 


Figure 11.5. Algorithm 11.2 applied to the circle @. The instructions executed are the 
following. 

We cheat and pick n = 10. Label chords 10, 9, 8, 7, and 6. Create dummy 5’ and skip over 9’. 
Label chord 4. Create dummy 3’ and skip over 8’. Label chord 2. Create dummy 1’ and skip 
over 6’, 10’, 2’, 4’, and 7’. The permutation is x = [7, 4, 2, 10, 6, 1, 8, 3, 9, 5]. 


Proof. Suppose j and k are adjacent in H[z] and assume j < k. Then 
there is an i such that i <j < k and their primed versions appear in the 
clockwise order j’, k’, i’. This implies that j’ and k’ are not dummy endpoints.* 
Since unprimed numbers occur in decreasing order going counterclockwise, 
it follows that the jth and kth chords intersect. 

Conversely, if the jth and kth chords intersect with j < k, then k’ was 
skipped over after labeling some dummy endpoint i’, where i <j. So 
mj) <1, ' <x,‘ andjand k are adjacent in H[z]. | 


For small examples these algorithms are easy to do by hand. We would 
like to suggest a data structure suitable for performing the algorithms on a 
computer. A circle @ with chords may be represented by either a list or an 
array consisting of the endpoints of the chords given in the counterclockwise 
order, beginning with a fixed but arbitrary starting point. There will be 
pointers providing direct access from one endpoint of a chord to the opposite 
endpoint. An example of this data structure is given in Figure 11.6. Notice 
that ARRAY(i) = ARRAY(OPPOSITE()) for all i in the example. 

To implement Algorithm 11.2 we scan the data structure corresponding to 
@ once from left to right, labeling endpoints appropriately The property of 
an endpoint being primed can be coded into the label. On the other hand, 
Algorithm 11.1 would receive its input 2 as the reversed list [z,,..., 22, 2] 
into which the new nodes are inserted. As the list is scanned from right to 
left, we keep track of which numbers have been passed by using an auxiliary 
bit vector. Both of these implementations can be carried out in time and 
space proportional to the size of the input. 


* Because any dummy endpoint following i’ counterclockwise would have smaller value. 
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12345 6 78 9 101411243 44 
aray: {3]1]7|3[6]4[5][6]2]7]2]1 [4] 5) 
Opposite: [4 ]12}10] + [8 ]13}14) 5 14] 3}9] 21617 | 


Figure 11.6. Data structures for a circle with chords. 


Mark Buckingham has suggested the following algorithm to construct the 
adjacency sets of the intersection graph obtained from a circle with chords. 


Algorithm 11.3. 

Input: The data structure DS, as described above, representing a collection 
of n chords of a circle. 

Output: The adjacency sets of the intersection graph. 

Method: The algorithm is given in Figure 11.7. We traverse DS (i.e., the 
circle counterclockwise) exactly once. Chords j and k intersect if and only if 
their endpoints occur in the order [k, j, k, j] or Lj, k, j, k]. Each chord k is 
added to the end of a list called LIST when its first endpoint is encountered 
(line 4). It remains there until the second endpoint is reached at which time 
all chords j on the LIST following k are discovered to intersect chord k 
(lines 5-7). Then k is removed from the LIST (line 8). An array POINTER(A), 
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begin : 
1. initialize: LIST — @; fori 1 tondo Adj() — @;; 
2, for each entry & of DS do in order 


3. if k is not on LIST 
then 
4. append & to the tail LIST; 
else 
ny for each j to the right of k on LIST do 
6. add j to Adj(k); 
L: add k to Adj (/); 
next /; 
8. delete k from LIST; 
next k; 
end 


Figure 11.7. Algorithm 11.3. 


initially undefined, may be used to execute efficiently the test in line 3 and the 
access to the starting point in line 5. A proof of correctness is left as Exercise 8. 


Remark. Touchard [1952], Riordan [1975], and Read [1979] investigate 
a generating function for the number of ways of drawing n chords of a circle 
so as to obtain & intersections. 


3. Overlap Graphs 


The circle graphs are equivalent to yet another popular class of graphs, 
namely, the overlap graphs. Given a collection of intervals on a line, each pair 
of intervals will satisfy exactly one of the following properties. 


Overlap. The two intervals intersect but neither properly contains the 
other. 

Containment. One of the two intervals properly contains the other. 

Disjointness. The two intervals have empty intersection. 


A graph G is called an overlap graph if its vertices may be put into one-to-one 
correspondence with a collection of intervals on a line such that two vertices 
are adjacent in G if and only if their corresponding intervals overlap (not 
just intersect). Without loss of generality we may assume that the intervals 
are either open or closed and that no two intervals have a common endpoint. 

Let ¥ = {1,},<y bea collection of intervals on a line, and assume that no 
two intervals have a common endpoint. The pairs of distinct indices are 
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partitioned into three mutually disjoint sets A, B, D as follows: For distinct 
x yeV, 
xyeA if OF1,01 #4 1,,1, 
(.e., the intervals overlap); 
xyeB if either], cI, or I,c I, 
(i.e., one interval properly contains the other); 
xyeD if Lal=0 
(i.e., the intervals are disjoint). 


Clearly, A, B, and D are symmetric relations partitioning all pairs. Thus we 
have that (V, A) is the overlap graph represented by .¥, (V, A + B) is the 
interval graph represented by .¥, and (V, D) is a comparability graph since 
its complement is an interval graph. Furthermore, defining 
xyeCc toed. 
and 
xyeF if J, lies entirely to the left of J,, 


it follows that (V,C) and (V, F) are transitive orientations of (V, B) and 
(V, D), respectively. An example of these graphs is illustrated in Figure 11.8. 


oe —_._—_ >! — 
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Figure 11.8. (a) A collection. of intervals. (b) The overlap graph (V. A) of .¥. (c) The interval 
graph (V, A + B) of ¥. (d) The transitive orientation (V, C) representing proper containment. 
(e) The transitive orientation (V, F) representing disjointness. 
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Figure 11.9. Intersecting chords of the circle correspond to overlapping intervals on the line. 
This projection method is suggested by Gavril [1973]. Relative to this choice of p, we have 
I, and J, overlapping, J, and J, overlapping, /, and J, disjoint, and J, containing J/,. 


We have the following easy result. 


Proposition 11.4. An undirected graph G is a circle graph if and only if 
G is an overlap graph. 


Proof. Given a circle with chords, choose a point p on the circle which is 
not an endpoint of a chord. To each chord with endpoints c and c’ we associate 
the arc along the circle from c to c’ which does not contain p. If the circle is 
cut at point p, then we will obtain a line with a collection of intervals having 
the desired property. 

This process may be reversed by wrapping a collection of intervals of a 
line around a circle and then drawing a chord between the two endpoints of 
each interval. | 


An alternate way to visualize this equivalence is by placing the circle 
tangent to a line, with p as the north pole, and the point of tangency as the 
south pole. Projecting the chords down to the line, as in Figure 11.9, we 
obtain the correspondence. Our data structure for representing a circle with 
chords is simply a discrete version of this linearization. 


4. Fast Algorithms for Maximum Stable Set and 
Maximum Clique of These Not So Perfect Graphs 


In the preceding sections we demonstrated the equivalence of the stack 
sorting graphs, the circle graphs, and the overlap graphs. We are therefore 
free to choose whichever model suits us best in order to prove properties 
about the class. 

As we mentioned earlier, there are a number of open problems concerning 
this class of graphs. 
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(i) Find an algorithm which recognizes circle graphs and constructs a 
representation for the graph as intersecting chords of a circle. 
(ii)* Are the coloring and clique-cover problems NP-complete for circle 
graphs? 
(iii) Is the strong perfect graph conjecture true for circle graphs? 


The stable set problem and the clique problem are tractable when restricted 
to our not so perfect graphs. In the context of open problem (i), it is essential 
that we be given, a priori, a representation of the graph as overlapping 
intervals, intersecting chords, or a permutation to be sorted. We choose to 
use the overlap graph model. We first present a solution to the stable set 
problem, due to Gavril [1973], which can be implemented to run in poly- 
nomial time. 

Let % = {1,},-y be a collection of intervals, let G = (V, A) be the overlap 
graph of .%, and let C and F be the oriented containment and disjointness 
relations as defined in the preceding section. For all xe V, let 


U(x) = {ve Vl] vox eC} 


be the set of indices whose corresponding intervals are (properly) contained 
in ],. The algorithm is as follows. 


Algorithm 11.4. Maximum stable set of an overlap graph. 


Input: The (transitively) oriented containment relation (V,C) and the 
(transitively) oriented disjointness relation (V, F) of a collection ¥ of inter- 
vals whose overlap graph is G = (V, A). 

Output: A maximum stable set S of G. 

Method: We assign, to each vertex xe V, a weight w(x) and a maximum 
stable set S(x) of G,, uy, where w(x) = |S(x)|. This is carried out recursively 
in such a way that vertices are assigned weights in a topologically sorted 
order with respect to C. At the heart of the algorithm is the subroutine (from 
Chapter 5) MAXWEIGHT CLIQUE, which finds a set of pairwise disjoint 
intervals {1,},.7 that generates, in line 6 of MAXSTABLE, the best possible 
stable set. The entire algorithm consists of the single call, 


begin 
S «+ MAXSTABLE(V); 
end 


and uses the recursive procedure in Figure 11.10. The assumption that F is 
transitive is crucial since it allows line 5 to be executed efficiently. 


* Garey, Johnson, Miller. and Papadimitrious [1979] report that the coloring problem for 
circle graphs is NP-complete. 


246 11. Not So Perfect Graphs 


procedure MAXSTABLE(X): 
begin 
if X = @ then return @;; 
while there exists x € XY with w(x) undefined do 
S(x) — {x} U MAXSTABLE(U(x)); 
w(x) — [SOx] 5; 
T — MAXWEIGHT CLIQUE(Y, Fy); 
return U,<7 S(v); 
end 


Dy oN 


Figure 11.10 


Theorem 11.5 (Gavril [1973]). Algorithm 11.4 correctly finds a maxi- 
mum stable set of an overlap graph. 


An example of Algorithm 11.4 applied to the intervals in Figure 11.8 
follows the proof of the theorem. 


Proof. We shall show that the procedure returns a maximum stable set 
of the subgraph G, = (X, Ay) for any subset X © Vsatisfying U(x) < X for 
all x € X. The claim is certainly true if |X| = 0. Assume that it is true for all 
subsets smaller than X. In particular, by induction, S(x) — {x} is a maximum 
stable set of Gy,,), so S(x) is a maximum stable set of G4 uj for each 
xe Xx, 

Let T be as defined in line 5. Since the intervals {/,},,.7 are pairwise dis- 
joint, and since I, <I, for all xeS(v) — {v} and ve T, it follows that 
J = Jver S(v) is a stable set of Gy. Thus 

a(Gy) > >) w(v) = [J]. (1) 
veT 
We must show that J is maximum. 

Let J’ be a maximum stable set of Gy, and let T’ be the set of sinks of 

(J’, Cy); Le., 


T’ = {yeJ'|I, < I, implies z ¢ J’}. 


Note that the intervals represented by T’ are also pairwise disjoint, so, by the 
correctness of MAXWEIGHT CLIQUE, 


Y wy) < ¥ wv). (2) 
yeT’ veT 
Now, clearly, if S‘(y) = {xeJ'|I, < I}, then |S’(y)| = w(y) for all y € T’, for 
otherwise we could replace S’(y) with S(y) and obtain a larger stable set. 
Hence, 


a(Gx) = |J'|= ) w). (3) 


yeT’ 
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Combining (1)-(3), we obtain 
a(Gx) = |J], 


which concludes the required proof. | 


Example 11.3. We apply Algorithm 11.4 to the intervals of Figure 11.8 
in order to find a maximum stable set of their overlap graph G = (V, A). The 
vertices can be assigned weights in any topologically sorted order with respect 
to C. We arbitrarily choose the order a,c,e,g,d,b, f. Clearly, w(a) = w(c) = 
w(e) = wg) = 1 and S(a) = {a}, S(c) = {c}, S(e) = {e}, and S(g) = {g} 
since they are all sources of C. Next, S(d) = {d, e} and w(d) = 2 since MAX- 
WEIGHT CLIQUE (U(d), Fuja) = U(d) = {e}. Now U(b) = {c,d,e,g} and 
the heaviest clique in Fy) is {d, g}; thus S(b) = {b, d, g} and w(b) = 3. 
Similarly, Sf) = {f,g} and w(f) = 2. Finally, MAXWEIGHT CLIQUE 
(V, F) could be either {a, d,g} or {a,e, f}, both having weight 4. They give, 
respectively, the stable sets {a,d,e, g} and {a, e, f,g}. 


Next we provide an algorithm due to Gavril [1973] which solves the clique 
problem for circle graphs in polynomial time. The notions of matching 
diagram and permutation graph from Chapter 7 will be used. 

Let G = (V,E) bea circle graph with representing family {C,},,.y of chords 
of a circle @, and let N(v) = {v} + Adj(v). 


Lemma 1. For every vertex ve V, the induced subgraph Gy, is a permu- 
tation graph. 


Proof. We may assume that no two chords have a common endpoint. 
Thus, the chord C, cuts @ into two pieces such that for x € Adj(v) the chord 
C,, has one endpoint in each piece. Therefore, the subset D = {C,},- aaj iS 
a matching diagram whose permutation graph is Gagj,). Since connecting a 
new vertex to every vertex of a permutation graph results in another permuta- 
tion graph, it follows that Gy,,) is a permutation graph. I 


Lemma 2. If K is a clique of G, then K is a clique of Gy,,) for each ve K. 


Proof. Trivial. | 


Algorithm 11.5. Maximum clique of a circle graph. 
The algorithm is as follows: 


begin 
1. forve Vdo K, ~— MAXCLIQUE(Gy,,,); 
2. return the largest K,; 

end 
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By Lemma 1, statement 1 can be executed efficiently. By Lemma 2, the 
algorithm is correct. Details are left to the reader as Exercise 11. 


5. A Graph Theoretic Characterization of Overlap 
Graphs 


Although we have shown the equivalence of circle graphs, stack sorting 
graphs, and overlap graphs, we have not really characterized them from a 
traditional graph theoretic point of view. In this section we shall present 
such a characterization. The solution, however, will fall short of providing 
us with an efficient recognition algorithm. 


Theorem 11.6 (Fournier [1978]). An undirected graph G = (V, E) is an 
overlap graph if and only if there exists an acyclic orientation P of G and two 
linear extensions L, and L, of P such that the relation F = (L; 0 L,) — P 
satisfies 

xyeF,yzeL,>xzeF (4) 
and 


xyeL,,yzeF >xzeF. (5) 


Remark. Such a relation F is transitive. 


Proof. (=>) Let ¥ = {1,},.y be a collection of closed intervals on the 
real line, no two intervals sharing an endpoint, such that xx’ is an edge of G if 
and only if I, and I,, overlap (i.e., they intersect but neither contains the 
other). We denote J, = [a,b] and 1, = [a’, b’]. Consider the binary relations 
defined on V as follows: 

xx’eP ea<a<b<b, 

xx’'e Ly oa<d, 

xx el, eb< Db’. 
Clearly P is an acyclic orientation of G, and L, and L, are linear extensions 
of P. The relation F = (L, 0 L,) — P satisfies 


xx eFea<b<a<J' 


and represents J, being entirely to the left of I... It is easy to see that (4) and 
(5) are satisfied. 
(=) Inthe remainder of the proof, for any binary relation R we denote 


R(x) = {y|xye R}. 
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Let G = (V, E) be an undirected graph on a vertices and let P, L,, Lz, and 
F satisfy the conditions of the theorem. To a vertex x of G we associate the 
interval I, = [a, b] as follows: 
a=1+ |Ly'(x)| + |P7*)L, 
b = In — |L,(x){ — | P(x)I- 


We shall show that % = {I,},-y is an overlap representation of G. 


Claim!1. 1<a<b<2n. 
We shall prove the inequality a < b, the others being trivial. By the 
definitions of a and b, it is enough to prove the inequality 


[Ly *(x)| + [F7*(@)| + [L20)| + [FQ] < 2 — 1). (6) 
If x’e F~'(x), then x’ ¢ L(x), because F < L, and L, is antisymmetric; 
thus F- 4(x) 0 L(x) = @. Similarly, F(x) A Ly (x) = @. Thus, each mem- 
ber x’ of V is counted at most twice on the left side of (6) except for x itself, 
which is not counted at all. This proves Claim 1. 
For vertices x and x’ (x # x’), where I, = [a,b] and I, = [a’,b’] are 
defined as above, we shall show the following three implications: 


Claim 2. 
(i) xx’'eL, —(PUF)=a<a <b’ <b, 
(il) xx’eF=>b<a, 
(iii) xxeP=>a<a<b<bB’. 
Notice that xx’e L, — (P u F) ifand only if xx’e L, — L,, and since L, isa 
total order, implication (i) would follow directly from 


(i) xx’eL,;>a<a' and (i2) xx'EL, =>b< BD’. 

Let xx’e€L,. Since L, is a total order we have Lj (x) ¢ Ly '(x’), and 
thus |Ly1(x)| < |Ly'(x’)|. (The strict inequality is due to x ¢ Ly '(x') and 
x’ ¢ Ly 1(x).) Also, from property (i,), we have F~1(x) < F~1(x’), so | F7 *(x)| 
< |F~1(x’)|. Combining these inequalities we obtain 

[Ly *(x)| + [FOTG)| < [Lr '@)| + [FOUL 


which yields a < a’ and proves (i,). Implication (i,) is proved in the same 
fashion. This proves (i). 
For implication (ii) we shall show that if xx’e F, then 


[Ly '(x’)] + [Fo 'G)| + [L200] + [FG] = 22. (7) 


Let x”eV. If x"€L7'(x’) (ie, x’x” ELT"), then x'x”eL, since L, is a 
total order; moreover, (4) implies that xx” € F (ie., x” € F(x)), and hence 
x” éL,(x). In an analogous manner, if x” ¢ L(x), then x” F~'(x’) and 
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x” € Ly '(x'). Thus, each vertex of V, including x and x’, is counted at least 
twice on the left side of (7). This proves (ii). 

For implication (iii), since (i,) and (i) hold, it is sufficient to show that if 
xx’ € P then a’ < b, or equivalently, if xx’ e P, then 


[Ly (x) + IFA) + [L209] + [FQ] < 2m — 1). (8) 


It is easy to verify that if x” ¢ F~ ‘(x’) then x” ¢ L,(x) and x” ¢ F(x) (since F 
is a transitive relation). Similarly, if x” ¢ F(x), then x” ¢ Lj \(x’) and x’¢ 
F~1(x’). Thus, each element of V is counted at most twice on the left side of 
(8), except for x and x’, which are counted exactly once each (x € Ly !(x’) 
and x’ € L,(x)). This proves (iii) and concludes Claim 2. 

Finally, the three conditions of (i)-(iii) are mutually exclusive and cover 
all possibilities. Therefore, the opposite implications also hold in (i)-(i1i). In 
particular, 


xx ePsea<a<b<bJ’. 
Since P is an orientation of G, we conclude that 
xx'€G<>I, and I,. overlap, 


and ¥ = {I,},.-y is the desired overlap model of G. i 


Remark. Ifthe relation Fin Theorem 11.6 is empty, then G is a permuta- 
tion graph; conversely, for every permutation graph there exist relations 
P,L,,and L, as inthe theorem with P = L, q L, (asin the proof of Theorem 
7.1.) However, even when G is a permutation graph there may very well exist 
other relations P, L,, and L, satisfying the conditions of the theorem for 
which P # L, OL,. For example, letting G = K, with P= @, L, = 
{x <y<z],and L, = [x <z < y], we obtain L, NL, 4 ©. 


Historical Note 


We began this chapter by discussing a problem using stacks. We conclude 
with an historical note on one of the oldest written references to the notion of 
“last-in, first-out.’* The reference occurs in a commentary by Rashi (Rabbi 
Solomon ben Isaac) on the Biblical verse 


Then his brother emerged, his hand seizing Esau’s heel; so they named 
him Jacob.} Isaac was sixty years old when they were born [Genesis 
XXV, 26]. 


* We are indebted to Gideon Ehrlich for pointing out this reference in a communication with 
Edward M. Reingold, who then passed it on to the author. The translation of the Rashi quotation 
is due to E. M. Reingold. 


+ In Hebrew, Ya’akov, play on the word ‘aqev meaning “heel.” 
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Rashi lived from 1040 to 1105 a.b., residing primarily in Troyes, France, 
his birthplace, where he founded one of the leading schools of the time. He is 
the most famous biblical and talmudic commentator in all of Jewish history. 
His commentary on this verse is as follows: 


I heard a Midrashic legend expounding on the meaning [of the phrase 
“Then his brother emerged ...”]. It was his [Jacob’s] right, the grasping 
of his [Esau’s] heel: Jacob was conceived from the first drop and Esau 
from the second. Consider a tube with narrow mouth. Put two stones 
into it, one after the other—the first to enter exits last and the last to 
enter exists first. It is [thus] found [that] Esau, conceived last, exited 
first, and Jacob, conceived first, exited last. [Thus] Jacob went to delay 
him [Esau] so that he [Jacob] would be first born [just] as he was first 
produced and to be a first fruit of the womb and to take the birthright 
[as he deserved] according to the law. 


Rashi is clearly describing a stack mechanism. 


EXERCISES 


1. Find a permutation x whose graph H[z] is a chordless pentagon plus 
some isolated vertices. 

2. Using the data structure suggested in the text, write computer programs 
to implement Algorithms 11.1 and 11.2 and test them on the examples given 
in this chapter. 

3. Does H[x] always have some isolated vertices? Prove that if H[x] has 
exactly one isolated vertex then H[x] = G[x] but not conversely (see 
Chapter 7). 

4. Show that if the output of Algorithm 11.2 is used as the input of Al- 
gorithm 11.1, then the resulting composition may change the set of chords. 
Modify Algorithm 11.2 so that this does not happen. 

5. By an arbitrary convention we have discussed sorting a permutation z 
in a parallel system of stacks from right to left. The problem of sorting x 
from left to right* is equivalent to forming z from [1, 2,...,n] from right to 
left. In this case one should study the coloring problem on the undirected 
graph H(z] having vertices {1,2,...,} with i and j adjacent if there is a k 
such that i<j<k and a'<12;'<2;'. In general the chromatic 
numbers of H[z] and H?[z] are different. 


* n would emerge first and 1 last. 
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Let the function p:ite+n + 1 — i act on the labeled vertices of a graph* 
and be composed with other permutations in the obvious way. Also let 
KH? = {G|G = H?[x] for some z}. Prove the following: 


(i) po H*[x] = H[penop], 
(ii) poH[nx] = H*[ponop], 
(ili) A= #°. 
6. Let the graph H[x] be properly colored using t colors. Show that the 
following algorithm correctly sorts 2 using a network of t stacks in parallel. 
Input: The permutation 2 with the numbers properly colored. 
Output: The permutation [1, 2,..., n] sorted. 
Method: The t stacks are in one-to-one correspondence with the colors. 
The algorithm is as follows: 
begin 
kel; 
while k < ndo 
if k can be moved onto the output queue then 
move & onto the output queue; 
else 


move the next number of the input queue onto the stack of its color;; 
end 


7. Show that a permutation 2 can be sorted in a network of k stack in 
parallel under the restriction that all numbers must be loaded into the stacks 
before any unloading can begin if and only if its reversal x° can be sorted ina 
network of &k queues in parallel. Give some additional equivalent con- 
ditions. 
8. Prove that Algorithm 11.3 correctly calculates the adjacency sets of the 
graph G = (V, E) of intersecting chords of a circle. Show that the algorithm 
can be implemented to run in O(|V| + |E]). 
9. Let f(n) be the length of the shortest string of numbers from {1, 2,...,n} 
which contains all a! permutations as subsequences. Prove that f(n) < n? — 
2n + 4(n = 3) (Koutas and Hu [1975]). 
10. Determine the computational complexity of Algorithm 11.4. 
11. Determine the computational complexity of Algorithm 11.5 taking into 
consideration that each subgraph Gy,,, must be calculated. 
12. Acircle @ with chords admits an equator if an additional chord may be 
added to @ which will intersect every other chord. 

(i) Prove that G is a permutation graph if and only if G is the intersection 
graph of a circle of chords which admits an equator. 

(ii) Give an example of a circle @ which does not admit an equator but 
whose intersection graph is a permutation graph. 
13. The sequence of operations used in sorting the permutation [3,5,4,1,6,2] 


*denoted p- G. 
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as in Section 11.1 can be abbreviated by the code 
S,S,S,S,X ,S38,X 1X X2X 2X3, 


where S; stands for “move the next number from the input queue onto 
stack i” and X; stands for “move the number at the top of stack i to the 
output queue.” Some sequences of S,’s and X,’s specify meaningless opera- 
tions; for example, the sequence S$,S,S,X,X,S,;X.X,S,X, cannot be 
carried out. 

We call a sequence of S,’s and X;’s admissible if it contains the same 
number of S;s and X;’s for each integer i, and if it specifies no operation that 
cannot be performed. Formulate a rule which distinguishes between ad- 
missible and inadmissible sequences (Knuth [1969, Exercise 2.2.1, No. 3]). 
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CHAPTER 1 2 


Perfect Gaussian Elimination 


1. Perfect Elimination Matrices 


Let M be a nonsingular n x n matrix with entries m,; in some field (like 
the real numbers). We reduce M to the identity matrix I by repeatedly 


(a) choosing a nonzero entry m,; to act as pivot and 

(b) updating the matrix by using elementary row and column operations 
to change m,; to 1 and to make all other entries in the ith row and jth column 
equal to 0. 


This familiar technique is called Gaussian elimination* and can be found in 
most books on linear algebra. 

When performing Gaussian elimination on a sparse matrix, an arbitrary 
choice of pivots may result in the filling in of some zero positions with 
nonzeros. One may ask, when is there a sequence of pivots which induces no 
fill-in? A perfect elimination scheme for M is a sequence of pivots which 
reduces M to I without ever changing a zero entry (even temporarily) to a 
nonzero. Such a sequence does not exist for every matrix. When M has a 
perfect elimination scheme and M is also sparse, then the sparseness can be 
preserved throughout the reduction. This is important for the storage 
requirements of M since a sparse matrix is most efficiently represented in a 
computer by listing its nonzero entries. 


*In practice one usually “zeros out” just the jth column postponing calculations on the 
ith row until the end, at which time back substitution is used. For our purposes the methods are 
the same. 
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@1 11 10 0 0 10 0 0 100 0 

Bad fa oo 0 @-1 -1 01 0 0 Ot OO 
5 => = 

Choice: | 1 0 1 0 0-1 3-1 0 0 @)-4 001 0 

1001 0-1-1 3 00-4 8 00 0 

4 

4111 ae ae ae) 2100 1000 

Good 1 10 0 110 0 1@0 0 0 10 0 
. = > > 

Choice: | 1 0 1 0 10@o0 0010 0010 

100@ 0001 0001 0001 


Figure 12.1. Two reductions of a matrix. 


Examples. Two reductions of the same matrix are given in Figure 12.1; 
the first introduces new nonzeros but the second does not. What causes the 
fill-in? It is easy to see that pivoting on a nonzero entry m;; will introduce 
some fill-in if m,; A 0 and m,, 4 0 but m,, = 0 for some s and t (see Figure 
12.2). The matrix in Figure 12.3 is nonsingular but has no perfect elimination 
scheme. Any entry chosen as the first pivot will cause some fill-in. A tri- 
diagonal matrix, as indicated in Figure 12.4, has a number of perfect elimina- 
tion schemes, one being the positions on the main diagonal ordered from top 
to bottom. 


Figure 12.2. Choosing position (i, j) as pivot results in filling in position (s, ¢). Thus the 
choice is unacceptable. The asterisks indicate nonzeros. : 


* * 
* * * 
1100 1 nS 
01101 +) 
011 £1 £0 * 
101 1 0 * 
1001 ] * 
Figure 12.3. A matrix with no perfect Figure 12.4. A tridiagonal matrix. The 


elimination scheme. asterisks indicate the nonzero entities. 
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Throughout this chapter we shall assume that M is nonsingular and that 
arithmetic coincidence does not cause new zeros to occur during the re- 
ductions.* 

Let us look at the problem graph theoretically. 

The graph G(M) of M has vertices v,,..., v,, with v;v; being an edge if and 
only if i # j and entry m,; # 0. The bipartite graph B(M) of M has vertices 
X1,---,X, and y;,...,y,, corresponding to the rows and columns, respec- 
tively, where x; is adjacent to y; if and only if m,; # 0. We call x; and y; part- 
ners; their correspondence with vertex v; of G(M) is obvious. 


2. Symmetric Matrices 


If M is a symmetric matrix, then G(M) is an undirected graph. In this case 
a nonzero diagonal entry m,; is acceptable as a pivot if and only if v; is a 
simplicial vertex of G(M). (Why?) In fact, pivoting on m,; is equivalent to 
making Adj(v,) into a complete subgraph by adding any missing edges and 
deleting v;. Therefore, the perfect elimination schemes for M under the 
restriction that 


(R) all pivots are chosen along the main diagonal whose entries are each 
nonzero 


correspond precisely to the perfect vertex elimination schemes of G(M). By 
Theorem 4.1 we obtain the equivalence of statements (ii) and (iti), first 
obtained by Rose [1970], in the following theorem. We present a generaliza- 
tion due to Golumbic [1978]. 


Theorem 12.1. Let M' be a symmetric matrix with nonzero diagonal 
entries. The following conditions are equivalent: 


(i) Mhasa perfect elimination scheme; 
(ii) M has a perfect elimination scheme under restriction (R); 
(iii) G(M) is a triangulated graph. 


Before proving the theorem, we must introduce a bipartite graph model 
of the elimination process. This model will be used here and throughout the 
chapter. 

An edge e = xy ofa bipartite graph H = (U, E) is bisimplicial if Adj(x) + 
Adj(y) induces a complete bipartite subgraph of H. Take note that the 


* Actually it is sufficient to assume that no coincidental new zero will be found in a position 
which we want to choose as pivot (expecting it to be nonzero) at the time when we want to choose 
it. 
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x, X% x3 XN, 
W, 2 Vz Ny 
Figure 12.5. 


bisimpliciality of an edge is retained as a hereditary property in an induced 
subgraph. Let o = [e, e2,---,@,] be a sequence of pairwise nonadjacent 
edges of H. Denote by S; the set of endpoints of the edges e,, ..., e;, and let 
So = ©. We say that o is a perfect edge elimination scheme for H if each edge 
e; is bisimplicial in the remaining induced subgraph Hy_s,_, and Hy-s, has 
no edge. Thus, we regard the elimination of an edge as the removal of all edges 
adjacent to e. For example, the graph in Figure 12.5 has the perfect edge 
elimination scheme [x,)1, X22, X33, X44]. Notice that initially x,y, is 
not bisimplicial. A subsequence o’ = [e,, e,..., &] of o (k <n) is called a 
partial scheme. The notations H — o’ and Hy_s, will be used to indicate the 
same subgraph. 

Consider the bipartite matrix B(M) of M. It is evident that bisimplicial 
edges of B(M) correspond precisely to acceptable pivots of M and that 
perfect edge elimination schemes for B(M) correspond to perfect elimination 
schemes for M. (See Figure 12.2 again in conjunction with Figure 12.6.) 


Proof of Theorem 12.1. We have already remarked that (ii) and (iti) are 
equivalent, and since (ii) trivially implies (i), it suffices to prove that (i) 
implies (ii). Let us assume that M is symmetric with nonzero diagonal 
entries, and let o be a perfect edge elimination scheme for B(M). 

Suppose G(M) has a chordless cycle [v,,, Vg.) - + + 5 Vays Ya, ]- This corresponds 
in B(M) to the configuration B, (Figure 12.7) induced by C = {X4,, Vaj-++> 
Xam» Yamt: Consider the first edge e of o involving a vertex of C. Clearly, e 
involves only one vertex of C since none of the edges of Bc is bisimplicial. 
Assume without loss of generality that e = x,, y, for some vertex y, ¢ C, and 
let x, be the partner of y,. 


Figure 12.6. The edge x,y, is not simplicial. A broken line indicates a nonedge. 
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Figure 12.7. The indicated subgraph B, of B(M). 


Since in Be, Adj(Xq,) = {Yass Yar? Yam} ANd Adj(y,,) O Adj(y,,) 0 AdIO,.,,) 
= {x,,}, the simpliciality of x,,y, implies that C m Adj(y,) = {x,,}, and by 
symmetry C 4 Adj(x,) = {yx,}. Thus, we have that x,, y., and x,y, are edges 
but x,y,, is not an edge, which contradicts the bisimpliciality of x,,y.. 
Therefore, G(M) is triangulated. 


Corollary 12.2. A symmetric matrix with nonzero diagonal entries can be 
tested for possession of a perfect elimination scheme in time proportional to 
the number of nonzero entries. 


Proof. Let m denote the number of nonzero entries of matrix M. If M is 
stored in O(m) space, then the data structures needed for applying Algorithms 
4.1 and 4.2 to G(M) can be initialized in O(m) time. The result follows from 
Corollary 4.6. I 


Theorem 12.1 characterized perfect elimination for symmetric matrices. 
Moreover, it says that it suffices to consider only the diagonal entries. 
Haskins and Rose [1973] treat the nonsymmetric case under (R), and 
Kleitman [1974] settles some questions left open by Haskins and Rose. The 
unrestricted case was finally solved by Golumbic and Goss [1978], who 
introduced perfect elimination bipartite graphs. These graphs will be dis- 
cussed in the next section. Additional background on these and other 
matrix elimination problems can be found in the following survey articles and 
their references: Tarjan [1976], George [1977], and Reid [1977]. A discussion 
of the complexity of algorithms which calculate minimal and minimum 
fill-in under (R) can be found in Ohtsuki [1976], Ohtsuki, Cheung, and 
Fujisawa [1976], Rose, Tarjan, and Lueker [1976], and Rose and Tarjan 
[1978]. 
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3. Perfect Elimination Bipartite Graphs 


The general problem of deciding if a given (nonsymmetric) matrix M has 
a perfect elimination scheme can be answered using the bipartite graph model 
introduced in the preceding section. A perfect elimination bipartite graph is 
one for which there exists some perfect edge elimination scheme. But how do 
we construct such a scheme? Is it possible to choose any bisimplicial edge, 
eliminate it, and then continue from there to construct the remainder of a 
scheme? The next theorem answers this question in the affirmative. (Through- 
out this section the term scheme will mean perfect edge elimination scheme.) 


Theorem 12.3 (Golumbic and Goss [1978]). Ife = xy isa bisimplicial edge 
of a perfect elimination bipartite graph H = (X, Y, E), then Hy ~.34y-4y is 
also a perfect elimination bipartite graph. 


Proof. We wish to show that if H has a scheme [e,, e,...,¢e,]} then it 
also has a scheme beginning with e. Let e; = x,y; with x;¢ X and y,e Y 
(i = 1, 2,...,n), and define H; to be the subgraph of H induced by X — 
ices Moi} Pee Hie 


Case 1. x =x; and y = y; for some i. Since bisimpliciality of an edge is 
preserved in induced subgraphs, it follows that [e, e,,...,@;—15 @i+15--+5 nl 
is a scheme. 

Case 2. x = x, and y = y; for some i 4 j. We may assume that i < j by 
interchanging X and Y if necessary; hence [e, e,,...,¢;-,] is a partial 
scheme. 

Consider an edge x,y, for some i < h < j. Suppose there exists anm > h 
such that x,,y, and x,y; are edges in H. We would then have the following 
implications: . 


x; y; bisimplicial in H; implies x,y; € E, 


x,y, bisimplicial in H,, implies x,,y;€ E, 
x;y; bisimplicial in H implies x,, y; € E. 


This shows that o = [e, €;,.... @;-1, €i4+45--+> @j—-1] 18 a partial scheme. 
Similarly, the following argument shows that e’ = x;y; is in H and is 
simplicial in H — o. If x;y, and x,y; are in E for s,t > j, then 


x;y; bisimplicial in H implies x;y; € E, 
x;y; bisimplicial in H; implies x,y; € E, 
x;y, bisimplicial in H; implies x,y, € E. 
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Since (H — a) ~ [e’] = Hj+,, we conclude that 
Dey Cin y Crp Ogee ay Cio ge eis seal 
is a scheme. 


Case 3. One of x and y is not among the x; and y,. Assume that x = x; 
and y # y; for some i and for all j. By an argument similar to, but shorter 
than, Case 2, [e, e;,---, €;-15 @j415-++5 €,] iS a Scheme. | 


Corollary 12.4. The greedy algorithm of repeatedly eliminating a 
bisimplicial edge of the remaining graph (thus also removing all edges 
adjacent to it) until no edge remains will succeed if and only if H is a perfect 
elimination bipartite graph. 


Proof. Assume the corollary is true for all subgraphs of H. If H is not 
perfect elimination, then the algorithm will surely fail (i.e., at some time 
before all edges are removed, there will be no bisimplicial edge). If H is per- 
fect elimination, then eliminate some bisimplicial edge e. Since H — [e] is also 
perfect elimination, we have, by induction, that the algorithm will succeed. Jf 


A pair of edges ab and cd of H = (U, E) is separable if the subgraph induced 
by them is isomorphic to 2K,. The graph H is said to be separable if it 
contains a pair of separable edges; otherwise H is nonseparable. Clearly a 
nonseparable graph has at most one nontrivial connected component. 
Furthermore, any induced subgraph of a nonseparable graph is non- 
separable. 


Theorem 12.5 (Golumbic and Goss [1978]). If H = (X, Y, E) is a non- 
separable bipartite graph, then each nonisolated vertex z is the endpoint of 
some bisimplicial edge of H. 


Suppose that z is a nonisolated vertex which is not the endpoint of any 
bisimplicial edge. We may assume that ze Y; let xpz be any edge. We shall 
construct an infinite chain of subsets of X 


XpeX{ oe Xp co 
which will contradict the finiteness of X. Assume we are given subsets 
X, = {X9,X4,---,%,} GX 
and 
Y= {2,Y--- MN SY 
such that 
xy,EEi <j foralO <ij<k 


4. Chordal Bipartite Graphs 261 


and 
x;zEE for allO <i<k. 


(The arbitrary edge xgz will start the induction when k = 0.) 

Since x,z is not bisimplicial, there exist vertices x and y (# z) such that 
x,y, xz € E but xy¢ E. Hence, y¢ Y,. Moreover, for all 0 < i < k the edges 
x;¥j+, and x,y are not separable, implying that x,;ye E. But xy ¢E, so 
x ¢ X,. Therefore, by renaming x = x,,, and y = y,,, and setting X,4, = 
X,U {x 4,} and Y,4, = Y, U {y,4,}, we are ready for the next iteration of 
our construction. This algorithm goes on indefinitely, but X and Y are finite, 
a contradiction. Thus H must have a bisimplicial edge with z as one of its 
endpoints. | 


Corollary 12.6. Every nonseparable bipartite graph A is a perfect elimi- 
nation bipartite graph. 


Proof. By Theorem 12.3, it suffices to show that H has a bisimplicial edge. 
The corollary follows from Theorem 12.5. 


We have accomplished two things in regard to perfect elimination bi- 
partite graphs: We have provided an algorithm for recognizing them, and 
we have proven a sufficient (but not necessary) condition for them. Being 
perfect elimination, however, cannot tell us much about the structure of a 
graph. Indeed, let H be any bipartite graph with vertices u,,u,,...,u,; add 
new vertices w,, W2,...,W, and connect u,; with w; for each i = 1,...,n. 
This augmented graph is a perfect elimination bipartite graph and completely 
masks the structure of H. It follows from this negative result that there 
cannot exist a characterization of perfect elimination bipartite graphs in 
terms of some forbidden configurations or subgraphs. 


4. Chordal Bipartite Graphs 


In the preceding section we have successfully generalized the perfect 
elimination aspect of triangulated graphs. This raises the following question: 
Is there an appropriate notion of chordality for bipartite graphs? A triangu- 
lated graph may have 3-cycles, but any longer cycle must have a chord. In 
bipartite graphs the smallest allowable cycle has length 4, so we make the 
following definition. A bipartite graph is chordal if every cycle of length 
strictly greater than 4 has a chord. 


Remark. Every nonseparable bipartite graph is chordal bipartite. 
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Separable edges can be equivalently defined as follows: A pair of edges ab 
and cd of G = (V,E) is separable if there exists a set S of vertices whose 
removal from G causes ab and cd to lie in distinct connected components of 
the remaining subgraph G,_,. The set S is called an edge separator for ab 
and cd; S is minimal if no proper subset of S is an edge separator for ab and 
cd. The next result is analogous to Theorem 4.1 (iii). 


Theorem 12.7 (Golumbic and Goss [1978]). A bipartite graph H = 
(X, Y, E) is chordal bipartite if and only if every minimal edge separator 
induces a complete bipartite subgraph. 


Proof. Let C = [v,, 02,...,%, 01] be a cycle of H having even length 
k > 6. Consider the set S = Adj(r,) + Adj(v3) — {v2, v3}. Clearly S separ- 
ates v,v3 from vsv,, and SAC = {v,, v4}. Let S’ < S be a minimal edge 
separator for v, v3 and v,v,. Thus v, € S’ and v, € S’. If S’ is complete bipartite, 
then v,v, is a chord of C due to the opposite parity of the subscripts. 

Conversely, let T be a minimal edge separator and let H, and Hz be con- 
nected components of the graph remaining after removing T. Let x and y be 
any pair of vertices of T of opposite parity. Since H, and H, are connected, 
there exist minimum length paths [x, a), a2,..., y] and [y, b,, b2,..., x] 
with a; € A and b; € B. Because these paths are of odd length = 3, they join to 
give a cycle of length > 6. If this cycle has a chord, it must be the edge xy, 
since by construction no other pair may be adjacent. Hence, T will be a com- 
plete bipartite set. | 


The next theorem generalizes Lemma 4.2 with separability in bipartite 
graphs corresponding to nonadjacency in undirected graphs. 


Theorem 12.8 (Golumbic [1979]). Let H be a chordal bipartite graph. 
If H is separable, then it has at least two separable bisimplicial edges. 


Proof. Assume that H = (X, Y, E) has separable edges « and f and that 
the theorem is true for all graphs with fewer vertices than H. Let S be a 
minimal edge separator for « and B with H, and H, being the connected com- 
ponents of Hy ,y_s containing « and f, respectively. We claim H,, 5 has a 
bisimplicial edge whose endpoints are both in A. 

Case 1. H,.5 is separable. By induction H,, 5 has two separable bi- 
simplicial edges x,y, and x, y,. Since S is complete, at most two of the four 
endpoints are in S, either those with the same parity or those with the same 
subscript. Suppose x,, x,¢S and y,,y,¢A. Take a minimum length path 
[y1,4,,---,4j, Yo] in Hy and a minimum length path [x2, b,,..., by, x1] 
with the b; in Hz. Gluing these together we obtain a cycle of length at least 6 
which must have a chord. But minimality permits only the chords x,y. or 
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Xy,, contradicting the separability of x,y, and x,y. Similarly y, and y, 
cannot both be in S. Therefore, H, ,.; has a bisimplicial edge whose endpoints 
are both in A. 

Case 2. H,4.5 is nonseparable. Let x,y, be any edge of H,. By Theorem 
12.5 there exist vertices y, and x, such that x,y, and x, y, are bisimplicial in 
H 445. Suppose both y, and x, are in S, for otherwise the claim is true. Then 
x, and y, are adjacent since S is complete. The bisimpliciality of x,y, implies 
that Adj(x,) © Adj4,s(x2), and the bisimpliciality of x,y, implies that 
Adj4+s(x2) S Adj(x,). Hence, Adj(x,) + Adj(y2) = Adj4+s(x2) + Adj(y2), 
which we know induces a complete bipartite subgraph. Thus, x,y, is also 
bisimplicial in H 4.5, $0 the claim for this case is proven. 

Finally, a bisimplicial edge of H,, 5 whose endpoints lie in A is also bi- 
simplicial in H since Adj(A) € A + S. Therefore, by the claim, H has a 
bisimplicial edge « whose endpoints lie in A and, similarly, a bisimplicial 
edge B’ whose endpoints lie in B, and «’ and f’ are separable. I 


The proof of Theorem 12.8 actually gives a slightly stronger result. 


Corollary 12.9. Let H = (X, Y, E) be a chordal bipartite graph. If S is a 
minimal edge separator for some pair of edges, then H has a simplicial edge 
in each nontrivial connected component of Hy.y_s. 


Theorem 12.10 (Golumbic and Goss [1978]). Every chordal bipartite 
graph is a perfect elimination bipartite graph. 


Proof. Since chordal bipartiteness is a hereditary property, it is sufficient 
to show that a chordal bipartite graph H has a bisimplicial edge. Applying 
Theorem 12.5 for H nonseparable or Theorem 12.8 for H separable, we 
obtain the desired result. i 


Unlike the case of triangulated graphs (Theorem 4.1), the converse of 
Theorem 12.10 is false. Each of the edges u;w; in Figure 12.8 is bisimplicial, 
and the elimination of any one of them breaks the 6-cycle. Nevertheless, we 
do have a necessary and sufficient condition for chordality in terms of perfect 
elimination by adding a hereditary condition. 


Corollary 12.11. A graph is chordal bipartite if and only if every induced 
subgraph is perfect elimination bipartite. 


Proof. If H possesses a chordless cycle C of length strictly greater than 4, 
then C would be an induced subgraph which is not perfect elimination. Con- 
versely, if H is chordal bipartite, then so is every induced subgraph H’, and 
by Theorem 12.10, H’ is perfect elimination. 
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Figure 12.8. A perfect elimination bipartite graph which is not chordal. The cycle is broken 
when one of the edges u;w; is eliminated. 


Summary 


We have presented bipartite generalizations of triangulated graphs accord- 
ing to two important properties: perfect elimination and chordality. Although 
these notions do not coincide in the general setting, both do extend certain 
aspects of triangulated graphs. Perfect elimination bipartite graphs correctly 
model the application to Gaussian elimination with no fill-in. Chordal 
bipartite graphs satisfy the separation theorems analogous to those of Dirac. 
Alan Hoffman and Michel Sakarovich have recently discovered that the 
chordal bipartite graphs give a characterization of the matrices in an im- 
portant class of linear programming problems for which the greedy heuristic 
approach gives an optimum solution. 


EXERCISES 


1. Verify that the matrix below has a perfect elimination scheme but does 
not have one under restriction (R). 


aA kh WN eS 
—— Oe ee 
eS Se 
Coe eo 
re et ( 
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2. Let G = (V, E) be an undirected graph with vertices v,, v,,...,0,-. The 
bipartite graph B(G) of G has vertices x,,x2,.-.,X, aNd yy, Vo,---3 Vas 
with x; adjacent to y; if and only if i = j or u,v; € E. 
(i) Show that if B(G) is chordal bipartite, then G is a triangulated graph. 
(ii) For which of the triangulated graphs in Figure 12.9 is B(G) not chordal 
bipartite? Find a minimal edge separator which does not induce a bipartite 
clique. 


Figure 12.9. 


3. Consider the graph H constructed as follows: [a,,...,4,,4,] and 
[b,,...,b,, b,] are vertex disjoint chordless cycles with n even, and a;b; is an 
edge iff i + j = 1 (mod 2). Show that H is not a perfect elimination bipartite 
graph for n > 6. 

4. Let H = (X, Y, E) be a perfect elimination bipartite graph with perfect 
scheme a. For xy € E define the deficiency of xy in G to be 


D(xy) = {ab ¢ Ela, b © Adj(x) + Adj(y)}. 
Show that ¢ is also a perfect scheme for the graph H’ = (X, Y, E + D(xy)). 


Suppose you made a stupid pivot choice and caused some fill-in on your 
perfect elimination bipartite graph; is all hope lost? No, you can still con- 
tinue perfectly, as the next exercise shows. 

5. If H = (X, Y, E) is a perfect elimination bipartite graph and xy is any 
edge, then the xy-elimination graph 


Ay = (X — {x}, ¥ — {y}, Ex-pysy-py + Dxy)) 


is also perfect elimination. (Hint: Use Theorem 12.3 or modify its proof.) Ifo 
is the perfect scheme for H which was misplaced when xy was stupidly 
eliminated, how can a be cleverly modified to give a perfect scheme for H,.,,? 
6. Prove the claim in case 3 of Theorem 12.3. 

7. Let H = (X,Y, E) bea bipartite graph and let H’ = (X, Y, FE’) denote its 
bipartite complement; that is, for all xe X and ye Y, xyeE’ iff xy¢ E. 
Prove the following: The graphs H and H’ are both chordal bipartite if and 
only if H contains no induced subgraph isomorphic to Cy, 3K,, or Cg 
(Golumbic and Goss [1978]). 

8 Let G =(V, E) be an undirected graph and let B(G) be its bipartite 
graph (see Exercise 2). For S < V, let B(S) = {x;|v,; ES} U {y, |v, ES}. Prove 
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that S is a minimal vertex separator of G if and only if B(S) is a minimal edge 
separator of B(G) (Golumbic [1979]). 
9. The Venn diagram in Figure 12.10 has nine regions representing all 
possibilities for a bipartite graph to satisfy or not satisfy the following 
properties. 

P.E.B. The graph is a perfect elimination bipartite graph. 

C.B. The graph is chordal bipartite. 
(P.E.B.)’ The bipartite complement of the graph is perfect elimination bi- 
partite. 

(C.B.) The bipartite complement of the graph is chordal bipartite. 
For each region give an example of a graph which lives in that region. (One 
solution is shown in Appendix E, but try to find your own examples without 
referring to it.) 


Bipartite Graphs 


Figure 12.10. Bipartite graphs. 


10. Let H =(X, Y,E) be a bipartite graph, and let G be the split graph 
obtained from H by connecting every pair of vertices in Y. Prove that H is 
nonseparable if and only if G is a threshold graph. For an application, see 
Chapter 10, Exercise 15. 
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Appendix 


A. A Small Collection of NP-Complete Problems 


GRAPH COLORING (decision version) 
Instance: An undirected graph G and an integer k > 0. 
Question: Does there exist a proper k-coloring of G? Equivalently, is 
y(G) < k? 
GRAPH COLORING (optimization version) 
Instance: An undirected graph G. 
Question: What is y(G)? 
CLIQUE (decision version) 
Instance: An undirected graph G and an integer k > 0. 


Question: Does there exist a complete subset of vertices of G of size k? 
Equivalently, is w(G) > k? 


CLIQUE (optimization version) 
Instance: An undirected graph G. 
Question: What is w(G)? 
STABLE SET (decision version) 
Instance: An undirected graph G and an integer k > 0? 
Question: Does G have a stable set of size k? Equivalently, is a(G) > k? 
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STABLE SET (optimization version) 
Instance: An undirected graph G. 
Question: What is «(G)? 


CLIQUE COVER (decision version) 
Instance: An undirected graph G and an integer k > 0. 
Question: Can the vertices of G be covered by k cliques of G? Equivalently, 
is k(G) < k? 


CLIQUE COVER (optimization version) 
Instance: An undirected graph G. 
Question: What is k(G)? 


HAMILTONIAN PATH 


Instance: An undirected graph G with vertices v,, v3,..., U,- 
Question: Can the vertices be ordered [v,,, Up, ..+, Ug, so that v,, and 
Un,,, are adjacent in G fori = 1,2,...,n — 1? 


HAMILTONIAN CIRCUIT 
Instance: An undirected graph G with vertices v4, v2,..., U,- 
Question: Can the vertices be ordered [v,,, 0,,,-.+, U,,] SO that v,, and 
v,,,, are adjacent in Gfori = 1,2,...,n — land v,, and v,, are also adjacent 
in G? 


STABLE SET ON TRIANGLE-FREE GRAPHS 
Instance: An undirected graph G having no 3-cycle. 
Question: What is «(G)? 


B. An Algorithm for Set Union, Intersection, Difference, and 
Symmetric Difference of Two Subsets 


Input: Two subsets S and T of a universal set U whose members are 
numbered u,,u,,..., u,. All subsets are represented as lists of numbers (the 
indices of its members). 

Output: ThesetsS UT,SOT,S — T, T — S,and(S — T) U(T — S). 
Method: An auxilliary Boolean n-vector B = <b,, b2,...,5,>, initially 
containing only zeros, is used. As the list S is scanned, B is changed to the 
characteristic vector of S (line 3). In the loop 4-9, S ~ Tand T — Sare formed, 
(S — T)U(T — S) is half formed, and B is changed to the characteristic 
vector of S — T. In the loop 10-15, S U T and (S — T) U(T — S) are com- 
pleted and S — T is formed. Also B is restored to the zero vector. 
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begin 

1. remark: B = <0,0,..., 0> 
2. initialize: SUT<-T;SaAT«+S~—~T+«T—-S<(S—T)vV(T-S)+@; 
3. for allie Sdo db; ~ 1;; 
4 
5 


for all je T do 
if B; = 1 
then 
‘6. Addjto S a T; 
7. b; — 0, 
else 
8. Addjto T — S; 
9. Add jto(S — T) u(T — S);; 
10. for allie Sdo 
1. ifb; = 1 
then 
12. Addito S UT: 
13. Add ito S — T; 
14. Add ito (S$ — 7) u (T — §); 
15. b, — 03; 
16. remark: B = <0,0,...,0> 


end 


Complexity. Assuming no charge for initializing B (line 1), the complexity 
is dominated by the three loops. Thus, the algorithm runs in O(|S| + |T|) 
steps. 


C. Topological Sorting: An Example 
of Algorithm 2.4 


Let us assume that the graph in Figure Cl is stored as sorted adjacency 
lists. Initially, the DFSNUMBER and the TSNUMBER of each vertex is 


Figure C1 
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DFSNUMBER(1)<1 


DFSNUMBER(2)<2 
DFSNUMBER(6)<3 
TOPSORT(2) TOPSORT(6) 
TSNUMBER(6)<-7 
TOPSORT(1) TSNUMBER(2)<-6 
DFSNUMBER(5)<—4 
TOPSORT(5) 
TSNUMBER(5)<-5 
TSNUMBER(1)<4 
DFSNUMBER(3)<5 
DFSNUMBER(4)<-6 
TOPSORT(3) TOPSORT(4) 
TSNUMBER(4)<3 
TSNUMBER(3)<—2 
DFSNUMBER(7)<-7 
TOPSORT(7) 
TSNUMBER(7)< 1 
Figure C2 


set to 0, j is set to 7, and i is set to 0. The search begins with vertex 1. TOP- 
SORT(1) will call TOPSORT(2), which will call TOPSORT(6); when 
control is eventually returned to TOPSORT(1) it will resume its scan of 
Adj(1) and will call TOPSORT(S). When TOPSORT(1) is finished, the main 
routine will call TOPSORT(3), etc. These recursive calls are illustrated in 
Figure C2. The final values of the depth-first search numbering and the 
topological sorting numbering are as follows: 


Vertex DFSNUMBER TSNUMBER 
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D. An lHlustration of the Decomposition Algorithm 


The decomposition algorithm in Section 5.4 as applied to a noncompara- 
bility graph is illustrated in Figure D1. 


é (V, E,) a, b, (V, 8) 
\ z 
y ° 
u yv 
x 
w 
2 2 
y 
u fu 
x 
Pa 
3 Zz 
y f} ty 
u 
cat v 
w 
Figure D1 


E. The Properties P.E.B., C.B., (P.E.B.)’, (C.B.)’ 
Illustrated 


Figure El! gives examples of graphs satisfying or not satisfying the follow- 
ing properties: 


P.E.B.: the graph is a perfect elimination bipartite graph; 
C.B.: the graph is chordal bipartite; 
(P.E.B.)’: the bipartite complement of the graph is perfect elimination 
bipartite; 
(C.B.)’: the bipartite complement of the graph is chordal bipartite. 
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Figure E1 


The regions in Figure E1 are illustrated by the given examples as follows: 


Region Example 


A, 
C,(n = 8,10, 12, -+-) 
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F. The Properties C, C, T, 7 IMlustrated 
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Examples of graphs which are or whose complements are comparability 


graphs and/or triangulated graphs: 
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1. Introduction — Foundations and Applications 


In this Epilogue chapter, we will take a “short tour” of some of the new results 
in algorithmic graph theory and perfect graphs. So many new research directions 
have been the subject of investigation since this book was first published in 
1980, that it is impossible to survey them all. The algorithms and applications 
associated with structured families of graphs have grown to maturity in these 
24 years. The literature has increased tenfold, and the world of perfect graphs 
has grown to include over 200 special graph classes. Perfect graphs now have 
their own Mathematical Reviews Classification 05C17, as so do geometric and 
intersection representations 05C62. 

We present here a sample of the many results of the Second Generation of 
Algorithmic Graph Theory from the author’s biased view. Necessarily, it must 
be only a small fraction of what would otherwise require a large sequel volume. 
Fortunately, the availability of several new books, listed earlier in the Prologue 
of this edition, can also aid the reader eager to pursue further exploration in this 
area. 

The sections of this Epilogue are numbered to correspond with the chapters 
of the book. Our intention is, as with the former chapters, to send the reader 
back to the literature, laboratory and library to continue research. 


Intersection Graphs 


We saw many of the early uses of the intersection graph model in the sneak 
preview Section 1.3, in the application sections on permutation graphs, interval 
graphs, and elsewhere in the book. But the volume and scope of research in this 
general area has expanded significantly both from the modeling and algorithmic 
points of view. Some of these applications include mobile frequency assignment 
(Osput and Roberts [1983]), pavement deterioration analysis (Gattass and 
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Nemhauser [1981]), relational databases (see Golumbic [1988]), evolutionary 
trees (see Waterman [1995]), physical mapping of DNA (Goldberg, et al. [1995], 
Golumbic, Kaplan and Shamir [1994]), container ship stowage (Avriel, Penn and 
Shpirer [2000]), and VLSI circuit design (Dagan, Golumbic and Pinter [1988]). 
Intersection graphs have become a necessary and important tool for solving 
real-world problems. McKee and McMorris [1999] is devoted to the topic of 
intersection graph models and their application. We will present several other 
examples in this new Epilogue chapter. 


Temporal Reasoning 


One of the “traditional” applications of interval graphs is reasoning about time 
intervals, which started with the original question of Hajés (Section 8.1, page 
171). Temporal reasoning is an essential part of many applications in artificial 
intelligence. Given a set of explicit relationships between certain events, we 
would like to be able to infer additional relationships which are implicit in those 
given. For example, the transitivity of “before” and “contains” may allow us to 
derive information regarding the sequence of events. Seriation problems, like 
the example in Section 8.4, ask for a mapping of temporal events onto the time 
line such that all the given relations are satisfied, that is, a consistent scenario. 
Similarly, there are problems of scheduling, planning, and story understanding 
in which one is interested in constructing a time line where each particular event 
or phenomenon or task corresponds to an interval representing its duration. 

Allen [1983] introduced a model for temporal reasoning using the thirteen 
primitive interval relations obtained by considering all possible orderings of their 
four endpoints. Several authors working in AI have studied and adapted Allen’s 
model further, and have incorporated such models into reasoning systems. The 
paper by Golumbic and Shamir [1993] has provided a bridge linking some of 
these temporal reasoning notions from the AI community with those of the 
combinatorics community. Their approach has been to simplify Allen’s model 
in order to study its complexity using graph theoretic techniques. We refer the 
reader to Golumbic [1999] which is a survey paper! on the topic, written in the 
same spirit as this book. It describes a number of directions of current work on 
reasoning about time, many of which employ graph algorithms. 


2. The Design of Efficient Algorithms 


Maximum Network Flow Problem 


Progress on lowering the computational complexity of the maximum network 
flow (MAXFLOwW) problem was presented in Table 2.1 as one of several illustrations 


! This survey paper also includes some of the author’s newest illustrative stories, “Goldie and the 
Four Bears”, “Will Allan get to Judy’s in time?”, and “Five Autonomous Golumbic Women”. 
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of closing the gap between the best known algorithms and the lower complexity 
bound. Further improvement for MAXFLOW have been given by Goldberg and 
Tarjan [1988] O(ne log(n?/e)), King, Rao and Tarjan [1994] O(ne + n°**) and 
One log. tog ny %)> Philips and Westbrook [1993] O(ne log,,,n + n*(logn)°**). 
We refer the interested reader to Cook, Cunningham, Pulleyblank and Schrijver 
[1998], Corman, Leiserson Rivest, second edition [2001], Goldberg [1998] and 
Johnson and McGeoch [1993]. 

Although it is not a central topic in studying perfect graphs, maximum network 
flow algorithms do play an important role in certain optimization problems on 
perfect graphs. For example, we invoked its complementary relative MINFLOW 
at the end of Section 5.7 when sketching a polynomial method for finding the 
stability number a(G) of a cocomparability graph. This method has subsequently 
been used as part of the algorithm by Narasimhan and Manber [1992] for the 
stability number of tolerance graphs. 


Graph Sandwich Problems 


In this book, we placed a major focus on the minimum coloring, maximum 
clique, and recognition problems for special families of graphs. Another impor- 
tant algorithmic direction has been the study of various completion problems. For 
example, the minimum completion problem requires adding a minimum number 
edges to an arbitrary graph G in order to obtain a new graph G’ which satisfies 
the desired property II, such as being an interval graph or a triangulated graph, 
see Garey and Johnson [1979], Yannakakis [1981]. One motivation for such 
completion problems is as a heuristic for coloring G, since ¥(G) < x(G’). 

Another variation of the completion problem, called the graph sandwich 
problem, is defined by allowing only some of the nonedges to be eligible to 
be added to the original graph. Specifically, given a graph G = (V,E) and a 
subset Ey C E of (optional) nonedges, we ask whether there exists a completion 
G' = (V,E') which satisfies the desired property II, such that E C £’ C EU Ep. 

Sandwich problems arise in applications where only partial information about 
the graph is known. The interval graph sandwich problem was shown to be 
NP-complete by Golumbic and Shamir [1993]. It arises in molecular biology in 
problems of physical mapping of DNA and in problems of temporal reasoning, 
similar in spirit to the early work described in Applications 8.2 and 8.3 on 
pages 182-183. For example, see Atkins and Middendorf [1996] and Golumbic, 
Kaplan and Shamir [1994]. 

Golumbic, Kaplan and Shamir [1995] investigates graph sandwich problems 
for other special families of graphs. Specifically, the sandwich problem is 
polynomial for split graphs, cographs, and threshold graphs, but is NP-complete 
for chordal graphs, proper interval graphs, comparability graphs, permutation 
graphs, and others (see also Golumbic and Trenk [2004, Sections 4.7—4.8]). 
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There is also a body of literature on graph modification problems, where one 
may add edges and delete edges to transform a graph G into a modified graph G’ 
satisfying a property II. The problem is to minimize the total number of additions 
and deletions, thus changing the edge set as little as possible. For a good survey 
and introduction to this area, see Natanzon, Shamir and Sharan [2001]. 


3. Perfect Graphs 


The Strong Perfect Graph Conjecture/Theorem 


In May of 2002, the announcement was made that the Strong Perfect Graph 
Conjecture (SPGC) of Claude Berge had been proven by the team of researchers 
consisting of Maria Chudnovsky, Neil Robertson, Paul Seymour and Robin 
Thomas [2002]. This most important result, after 42 years, is currently submitted 
for publication. 

The term Berge graph has been defined as an undirected graph which contains 
neither an odd chordless cycle Cy4; (an odd hole) nor its complement C+ 
(for k > 2) (an odd antihole) as an induced subgraph. Thus, what should now 
be called the Strong Perfect Graph Theorem states that an undirected graph is 
perfect if and only if it is a Berge graph, the “only if” direction being immediate. 

During the decades preceding this solution, a large body of research developed 
involving the structure of minimally imperfect graphs, (see Brandstédt, Le and 
Spinrad [1999, Chapter 14]). The spin-off effect of these investigations has been 
the birth of many new children in the world of perfect graphs, both new problems 
and a generation of young researchers. The collections edited by Berge and 
Chvatal [1984] and Ramirez-Alfonsin and Reed [2001] provide a good cross- 
section of the work in this area. 

Although proving the SPGC was a major mathematical challenge rather than 
an algorithmic one, it raised several related interesting algorithmic questions: Is 
there a polynomial time algorithm which recognizes whether or not an undirected 
graph G has an odd chordless cycle of length >5? Is there a polynomial 
time algorithm which recognizes Berge graphs? The second problem has been 
solved, by Chudnovsky and Seymour [2002], Chudnovsky, Cornuéjols, Liu, 
Seymour and VuSkovi¢ [2002], Cornuéjols, Liu and Vuskovi¢ [2002], and awaits 
publication. Combining this algorithm with the Strong Perfect Graph Theorem 
shows that there is a polynomial time algorithm which recognizes whether or not 
a graph is perfect. A solution to the first question has so far not been found (as 
of spring 2003), but when/if a solution is found, it will give an alternate solution 
to the second question by applying it to the graph and its complement. 

Finally, Vashek Chvatal maintains a perfect website” which contains a long list 
of references and historical notes. A useful technical report by Hougardy [1998] 


2 http://www.cs.rutgers.edu/“chvatal/perfect/problems.html 
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lists, for each ordered pair (C,, C2) of 96 classes of perfect graphs, whether the 
class C; is a subset of the class C), and if this is not the case, provides and exam- 
ple of a graph which is in C; but not in C2. An on-line tool for checking the class 
containment for a larger set of more than 200 graph classes has been developed 
at Rostock University>. It also contains the known complexity results for recog- 
nition of the classes, the maximum stable set and domination problems. Several 
unresolved containments and complexities remain as open problems. Figure 13.3, 
at the end of this Epilogue (p. 305), gives a complete hierarchy of some of the 
main classes of perfect graphs, ordered by inclusion (reprinted from Golumbic 
and Trenk [2004] where it appears together with separating examples). 


Stable Sets 


On the stable set problem for perfect graphs, there has also been progress. 
Grétschel, Lovasz and Schrijver [1981] have shown that the ellipsoid method of 
solving linear programming problems can be applied to obtain a polynomial al- 
gorithm to find maximum stable sets and minimum colorings for perfect graphs. 
Also, since G is perfect if and only if its complement G is perfect, this same 
approach can be used to find maximum cliques and minimum clique covers. 

The major importance of this result is that it generalizes what had been known 
for many classes of perfect graphs. Although the complexity of the algorithm is 
polynomial, it may not be practical to implement. As the authors point out, it is 
not intended to compete with the special purpose algorithms designed to solve 
these problems for interval graphs, cocomparability graphs, triangulated graphs, 
and other classes of perfect graphs which so often arise in applications. For 
further reading on algorithms for the stable set problem and the clique problem, 
see Hertz [1995] and Johnson and Trick [1996]. 


4. Triangulated Graphs — Chordal Graphs 


Throughout this book, we have followed the French tradition by using the 
name triangulated graph for an undirected graph containing no chordless cycle 
C, (k > 4). In this section, however, we will use its popular synonym chordal 
graph. Two important variations of chordal graphs will be briefly presented here, 
namely the strongly chordal and the weakly chordal graphs. As their names 
indicate, every strongly chordal graph is chordal, and every chordal graph is 
weakly chordal. Weakly chordal graphs are also perfect graphs. 


3 http://wwwteo.informatik.uni-rostock.de/isgci 
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Strongly Chordal Graphs 


Strongly chordal graphs, introduced by Farber [1985], specialize chordal 
graphs in several ways. They are characterized by several equivalent definitions 
using chords of a cycle, forbidden subgraphs and elimination orderings. We will 
also encounter these graphs later in Section 12 of this Epilogue in relation to 
chordal bipartite graphs. 

Let C = [u1,u2,..., Ux, 41] be a cycle of even length 2k > 6. A chord uju; € E 
is called an odd chord if one of i and j is even and the other is odd, that is, it 
divides C into two even length cycles. A graph G = (V,E) is defined to be 
strongly chordal if it is chordal and every cycle of even length greater than or 
equal to 6 has an odd chord. For example, referring to Figure F1 on page 275, 
the graphs G2, G3, Gq and Gs are strongly chordal, however, the others are not 
strongly chordal, as follows: G; and G¢ are not chordal so they are not strongly 
chordal; the graph G7 is chordal, but the 6-cycle going around the outside of the 
graph has no odd chord, so the graph is not strongly chordal. 

The graph G; is often called the 3-sun and is one of a family of forbidden 
subgraphs characterizing strongly chordal graphs. The k-sun S; (k > 3) consists 
of 2k vertices, a stable set X = {x,,x2,...,x,} and a clique Y = {¥1,32,...,x} 
and edges E, U Ey where Ey = {x1y1,y1x2,x2y2, y2x3,....XeVk. vex1} forms the 
outer cycle and E, = {y,yj|i # j} forms the inner clique. The suns are split 
graphs, so they are chordal by Theorem 6.3, but they are not strongly chordal 
since the outer cycle has no odd chord. 

A trampoline of order k (k > 3) is a graph obtained from a k-cycle C by 
adding for each edge of C a new vertex adjacent only to the two endpoints of 
that edge, and then adding enough chords to C to make it chordal. A complete 
trampoline is one in which all the chords are added to the cycle C, making it 
a clique and identical to the k-sun S,. It is not difficult to show that a chordal 
graph which contains an induced trampoline also contains a (smaller) complete 
trampoline. 

A vertex x is called simple if for every pair of neighbors y and z of x, either 
Ny) © N(z) or N(z) C Ny). An ordering of the vertices [vj,v2,...,v0,] is 
called a simple elimination ordering for G if v; is a simple vertex in the induced 
subgraph Hj, for all i, where H; = Gy, »,} is the subgraph remaining after 
U1,...,0;-, have been eliminated. Note that the 3-sun S3 (G7 on page 275) has 
no simple vertex, so it does not have a simple elimination ordering. 


A strong elimination ordering is defined to be an ordering of the vertices 
(v1, 02,...,Un] where, for alli <j <k < &, if vjvg, vjug, ojo, € E then vjug € E. 
It is an easy exercise to verify that simple elimination orderings and strong 
elimination orderings are special cases of perfect elimination orderings. 

The next Theorem, due to Farber [1983], provides the following characteriza- 
tions of strongly chordal graphs: 
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Theorem 13.1. The following conditions are equivalent for an undirected 
graph G = (VE): 
(i) G is strongly chordal. 
(ii) G has a simple elimination ordering. 
(iii) G has a strong elimination ordering. 
(iv) G is chordal and sun-free. 
(v) G is chordal and trampoline-free. 


Strongly chordal graphs are closely related to the class of chordal bipartite 
graphs (Section 12.4, page 261). We will present this connection below in 
Theorems 13.15 and 13.17. For further reading on strongly chordal graphs, and 
additional characterizations, see Brandstadt, Le and Spinrad [1999] and McKee 
and McMorris [1999]. 


Weakly Chordal Graphs 


Hayward [1985] introduced the class of weakly chordal graphs (also called 
weakly triangulated) as those having no induced subgraph isomorphic to C,, or 
to C, for n > 5. The class of weakly chordal graphs contains the class of chordal 
graphs, since C; = Cs and C,, contains induced copies of Cy for n > 6. Also, the 
weakly chordal graphs are perfect graphs. This result now follows immediately 
from the Strong Perfect Graph Theorem, however, the first proof was obtained by 
combining a result by Chvatal [1985], that neither a minimally imperfect graph 
G nor its complement G can contain a “star-cutset”, with a result by Hayward 
(1985], that if G is a weakly chordal graph (with at least 3 vertices) then either 
G or G must contain a “star-cutset”. 


We call vertices x and y a two-pair if every chordless path between x and y 
has exactly two edges. The weakly chordal graphs have been characterized using 
two-pairs as follows. 


Theorem 13.2. The following are equivalent: 
(i) G is a weakly chordal graph. 
(ii) Every induced subgraph of G is either a clique or has a two-pair. 
(ii) If edges are repeatedly added between two-pairs in G, the result is eventually 
a clique. 


The implication (ii) => (i) follows from the observation that nonadjacent 
vertices in C, or C, (n > 5) are not a two-pair. The implication (i) => (ii) is 
due to Hayward, Hoang and Maffray [1990], and (i) <=> (iii) is due to Spinrad 
and Sritharan [1995]. The latter equivalence also leads to an O(n*) recognition 
algorithm for weakly chordal graphs. 
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LexBFS 


In Section 4.3, we presented lexicographic breadth first search (LexBFS), 
using it to obtain the linear time algorithm for recognizing chordal graphs. We 
also mentioned that maximum cardinality search (MCS) provides a conceptually 
and computationally simpler method for getting a perfect elimination scheme by 
changing the Jabe/ of a vertex x from a “list” of the marked neighbors to a 
simple “counter” of those marked neighbors. Tarjan’s proof that MCS orderings 
correctly recognize chordal graphs can be found in Golumbic [1984]. 

Fans and friends might have been temporarily disappointed when MCS seemed 
to make LexBFS obsolete, but not for long! LexBFS has become useful in other 
contexts, including recognizing proper interval graphs, recognizing asteroidal 
triple-free graphs and several other algorithms. There are also results for LexBFS 
on the powers of chordal graphs and on distance hereditary graphs which have 
no analogous result for MCS. See Brandstaédt, Le and Spinrad [1999, Chapter 5] 
which also surveys characterizations of many perfect graph families in terms of 
special kinds of vertex orderings. 


Intersection Graphs on Trees 


Let T be a tree and let {7;} be a collection of subtrees (connected subgraphs) 
of T. We may think of the host tree T either (1) as a continuous model of a tree 
embedded in the plane, thus generalizing the real line from the one-dimensional 
case, or (2) as a finite discrete model of a tree, namely, a connected graph of 
vertices and edges having no cycles, thus generalizing the path P, from the one 
dimensional case. 

The distinction between these two models becomes important when measuring 
the size of the intersection of two subtrees. For example, in the continuous model 
(1), we might take the size of the intersection to be the Euclidean distance of a 
longest common path of the two subtrees. In the discrete model (2), we might 
count the number of common vertices or common edges. We use the expressions 
“nonempty intersection” and “vertex intersection” to mean sharing a vertex or 
point of 7, and “nontrivial intersection” and “edge intersection” to mean sharing 
an edge or otherwise measurable segment of T. 

Using this terminology, Theorem 4.8 (page 92) stated the following. 


Theorem 4.8. A graph is the vertex intersection graph of a set of subtrees of 
a tree if and only if it is a chordal graph. 


In contrast to this, Golumbic and Jamison [1985a] observed that the family of 
edge intersection graphs of subtrees of a tree yield all possible graphs, proving 
the following: 


Theorem 13.3. Every graph can be represented as the edge intersection graph 
of substars of a star. 
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Table 1. Graph classes involving trees 


Type of Interaction Objects Host Graph Class 

vertex intersection subtrees tree chordal graphs 

vertex intersection subtrees star split graphs 

edge intersection subtrees star all graphs 

vertex intersection paths path interval graphs 

vertex intersection paths tree path graphs or VPT graphs 
edge intersection paths tree EPT graphs 

containment intervals line permutation graphs 
containment paths tree ? (open question) 
containment subtrees star comparability graphs 


Proof. Let G = (V,E) be any graph, and let E = {e),...,e,}. Consider 
the star T formed by a central node u and leaves @1,...,@,. Define the substar 
corresponding to v; to be the substar 7; of T induced by {u} U {@|v; € er}. 
Clearly, ujv; € E if and only if 7; and 7; share an edge, namely edge ue, of T 
where ey = v;U;. iI 


We will see below, in Theorem 13.6, that a graph is the vertex intersection 
graph of substars of a star if and only if it is a split graph. 

Two different classes of intersection graphs also arise when considering simple 
paths (instead of subtrees) of an arbitrary host tree T. The path graphs, which 
we mentioned on page 94, are the subfamily of chordal graphs obtained as the 
“vertex intersection graphs of paths in a tree” and are also called VPT graphs. 
However, the graphs obtained as the “edge intersection graphs of paths in a tree”, 
called EPT graphs, are not necessarily chordal. The class of EPT graphs are not 
perfect graphs, and the recognition problem for them is NP-complete, Golumbic 
and Jamison [1985a, 1985b]. See also Monma and Wei [1986] and Systo [1985]. 


Table 1 summarizes the subtree graph classes we have discussed here and in 
Sections 13.5 and 13.6 below. A full treatment can be found in Golumbic and 
Trenk [2004, Chapter 11]. 


5. Comparability Graphs and the Dimension of Ordered Sets 


Comparability Invariants 


A graph can have many different transitive orientations, so there may be 
different partial orders with the same comparability graph. A property of partially 
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Fig.13.1. A function diagram and its intersection graph (which is isomorphic to Cg). 


ordered sets is called a comparability invariant if either all orders with a given 
comparability graph have that property, or none have that property. For example, 
we saw in Theorem 8.13 (page 187) and in Exercise 8.7 (page 194) that the 
properties of being a semiorder or an interval order are comparability invariants. 

The dimension of a partial order is also a comparability invariant, that is, dim 
P = dim Q whenever P and Q have the same comparability graph G; hence, we 
can denote this common value by dim G. The proof we gave for Theorem 5.39 
(page 139) is incomplete; a full correct proof can be found in Trotter [1992] or 
in Golumbic and Trenk [2004]. Those references may be consulted for further 
study on comparability invariant properties. 


Function Diagrams: the Intersection Mode! for Cocomparability Graphs 


Golumbic, Rotem and Urrutia [1983] have characterized the family of 
cocomparability graphs as the intersection graphs of function lines in a 
diagram which generalizes the matching diagrams (page 162) which represent 
permutation graphs. Their function diagrams are constructed as follows. 

Let L; and Lz be two horizontal lines. A continuous curve f connecting a 
point on L; with a point on LZ is called a function line if, whenever two points 
(x,y) and (x’,y’) on f have the same horizontal value y = y’, the points must 
be equal, i.e., x = x’. A function diagram consists of L; and L, and a set of n 
function lines connecting points on L; and Lj. The function diagram in Figure 
13.1 has six function lines. We note that a matching diagram is the special case 
in which the function lines are straight lines. 

Consider the following special type of function diagram in which the curves 
are piecewise linear. Let Ly, L2,...,L%4, be horizontal lines each labeled from 
left to right by a permutation of the numbers 1,2,...,”. For each i (1 <i <n) 
the curve f; consists of the union of the & straight line segments which join i on 
L, with i on L,4,; (1 < t < k). When k = 1, this is just a matching diagram; 
when k > 2, it is called the concatenation of k matching diagrams. 

The following theorem is due to Golumbic, Rotem and Uruttia [1983], and a 
proof can also be found in Golumbic and Trenk [2004]. 


Theorem 13.4. The following are equivalent. 
(i) G is the intersection graph of a function diagram. 
(ii) G is a cocomparability. 
(iii) G is the intersection graph of a concatenation of matching diagrams. 
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Moreover, if £ is the minimum value for which G is the intersection graph of 
a concatenation of matching diagrams, then dim G = @+ 1. 


Containment Graphs 


The containment graph G = (V,E) of a collection F={S;} of distinct subsets 
of a set S has vertex set V = {1,...,} and edge set E = {ij| either S; C S; or 
5; C S;}. A graph with such a representation is called a containment graph. The 
class of containment graphs is equivalent to the class of comparability graphs. 
Moreover, Golumbic and Scheinerman [1989] observed that every comparability 
graph can be represented as the containment graph of a collection of subtrees 
(substars) of a star. Dushnik and Miller [1941] characterized the containment 
graphs of intervals on the line as precisely those having partial order dimension 
2, and from Chapter 7, we recall that these are equivalent to the permutation 
graphs. Generalizing interval containment, Golumbic and Scheinerman [1989] 
also showed the following. 


Theorem 13.5. A graph G is the containment graph of rectilinear boxes* in 
d-space if and only if dim(G) < 2d. 


Yannakakis [1982] has shown that the complexity of determining whether an 
order P has dimension < k, for any fixed & > 3 is NP-complete. This answers 
the open problem stated in the footnote on page 138. A proof can be found in 
Mahadav and Peled [1995, Chapter 7]. Therefore, as a corollary of Theorem 
13.5, we conclude that the recognition problem for the containment graphs of 
boxes in the plane is NP-complete. 

As early as the Banff Conference in 1984, we posed the problem, “Char- 
acterize the containment orders of circles in the plane and their comparability 
graphs”, see Rival [1985, page 583]. Progress on this question can be found in 
Fishburn [1988], Scheinerman and Wierman [1988], and Scheinerman [1992]. 
Sphere orders are the generalization to higher dimension, and are also found in 
the literature. Characterizing the containment graphs of paths in a tree is still an 
open problem. 


New Complexities for Comparability Graphs, Transitive Orientation and 
Permutation Graphs 


New algorithms have been found for recognizing comparability graphs and 
permutation graphs, based on fast modular decomposition of graphs. Modular 
decomposition is the recursive version of the method we saw in Section 5.2. The 


4 Boxes with sides parallel to the axes. 
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first of these new algorithms were due to Spinrad [1985]. McConnell and Spinrad 
[1999] show how to find an orientation F of an arbitrary graph G = (V, £) such 
that F is a transitive orientation (TRO) of G if and only if G is a comparability 
graph. This is very good if there is other information guaranteeing that G is 
a comparability graph. However, this alone does not recognize comparability 
graphs, since the algorithm simply produces an orientation which is not transitive 
when G is not a comparability graph. Hence, to complete it to a recognition 
algorithm, one must test F to determine if it is transitive. 

The complexity of their method uses O(n + e) time to produce a linear ordering 
L, of the vertices which is then applied to E to produce an orientation F). It then 
uses O(n“) time to test whether F is transitive, where O(n) is the complexity 
to perform transitive closure or n x n matrix multiplication (currently n?3”°), In 
a similar fashion, they can produce another linear ordering L of the vertices 
which if applied to E will produce an orientation F, which will be transitive 
if and only if G is a cocomparability graph. So the complexity of recognizing 
cocomparabilty graphs is currently also O(n"). 

Interestingly, their method allows recognizing permutation graphs in O(n + e) 
time, by first producing L,, Zz and F; and calculating the in-degrees and out- 
degrees of F, and F>, but without actually producing F2, since otherwise the 
complexity will hit O(7”). These enable us to follow the construction in the proof 
of our Theorem 7.1 (pages 158-159), yielding a permutation representation for 
G, if G is a permutation graph, or a contradiction among the degrees if G is not 
a permutation graph. 


6. Split Graphs 


Theorem 4.8 stated that a graph is the (vertex) intersection graph of a set 
of subtrees of a tree if and only if it is a triangulated graph. McMorris and 
Shier [1983] give an analogous version for split graphs, which we recall are 
characterized as being both triangulated and cotriangulated (Theorem 6.3, page 
151). If the host tree T is a star Ky,,, then each induced subtree consists of either 
a substar containing the central node or just a single leaf node. It is easy to see 
that the graphs obtained in this restriction are precisely the class of split graphs, 
as observed in McMorris and Shier [1983]. 


Theorem 13.6. A graph G is the vertex intersection graph of distinct induced 
subtrees of a star K,,, if and only if G is a split graph. 


Proof. Recall that a graph G is a split graph if its vertices can be partitioned 
into a clique K = {x,...,x¢} and a stable set S = {y1,...,ye}. If G is 
a ae graph, consider the star T formed by a central node wu and leaves 
X1,.--,Xk,¥1>---s¥e, Where the subtree corresponding to y; € S is the single 
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leaf ¥, in T and the subtree corresponding to x; € K consists of the substar 
of T induced by {u,x;} U {¥,|y; € Adj(xi)}. Clearly, this is an intersection 
representation for G. Conversely, if we are given a representation for G as the 
intersection graph of distinct induced substars of a star, then those substars 
containing the central node correspond to a clique in G and the remaining 
subtrees (the single leaves) correspond to a stable set of G. i 


7. Permutation Graphs and Applications from Circuit Design 


Matching diagrams, like those we studied in Section 7.4, are used in circuit 
design for channel routing problems where a set of numbered pins on the upper 
side of the diagram must be connected (electrically) to a set of pins on the lower 
side. The area between the upper and lower horizontals is called the channel. 
When a pair of line segments connecting matched pins intersect, they must 
be placed on different silicon layers, similar to the altitudes for the aircraft in 
Application 7.1. Thus, the minimum number of layers needed to realize the 
diagram equals the clique number «(G) of its permutation graph G, the value of 
which can be calculated in O(n logn) time. We will discuss briefly two similar 
graph problems originally motivated by circuit design. The books by Lengauer 
[1990] and Shrwani [1995] give a comprehensive treatment of other VLSI design 
and routing algorithms. 


Cell Flipping in Matching Diagrams 


Golumbic and Kaplan [1998] have considered the following generalization 
of the channel routing problem above, which is motivated by “standard cell” 
technology. The numbers on each side of the channel are partitioned into 
consecutive subsequences, or cells, each of which can be left unchanged or 
flipped (i.e., reversed). This takes place at a stage where the cell placement on 
horizontal rows has already been performed, and the only remaining degree of 
freedom is replacing some of the cells with their “mirror image” with respect to 
the vertical axis, i.e., cell flipping. The questions asked are: 


MINFLIP: For what choice of flippings will the resulting clique number be 
minimized? 

MAXFLIP: For what choice of flippings will the resulting clique number be 
maximized? 


For example, let the upper sequence be partitioned [3, 4, 7], [2, 6], [1, 5, 8] and 
let the lower sequence be [6’, 2’, 5], [4’, 1’, 7’, 8’, 3’], where the brackets indicate 
cells. The clique number w(G) is 4 with no flipping but is reduced to 3 if we 
flip [2, 6], or is increased to 5 if we flip [2, 6] , [6’, 2’, 5’] and [4’, 1’, 7’, 8’, 3’]. 
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The complexity of the MAXFLIP problem is O(n’) using a dynamic program- 
ming algorithm, whereas the MINFLIP problem is NP-complete (see Golumbic 
and Kaplan [1998]). When one side of the channel is fixed (no flipping on that 
side), the problem of finding a flipping for the other side which maximizes the 
clique number can be found in O(n logn) time. Verbin [2002] has shown the 
complexity of the one side flipping problem for minimizing the clique number 
to be NP-complete. 

We note that the cell flipping problems could have been defined to minimize or 
maximize the stability number. It is clear, however, that these stability problems 
are computationally equivalent to our clique problems, since a(G) = w(G) and 
G is a permutation graph if and only if G is a permutation graph. For example, 
the 4 different one side flipping problems can be restated as follows: Given a 
permutation of the numbers 1,2,...,” partitioned into cells, find flippings which 
minimize/maximize the longest increasing/decreasing subsequence. 


Trapezoid Graphs 


Dagan, Golumbic and Pinter [1988] extended the notion of a permutation 
diagram by replacing each matching segment i-i’ by a trapezoid obtained from 4 
points a;, b;,c;,d; where interval I; = [a;, b;] lies on the upper line of the diagram 
and interval J/ = [c;,d)] lies on the lower line of the diagram. The intersection 
graphs of these trapezoid diagrams are called trapezoid graphs. Trapezoid graphs 
are a subclass of cocomparability graphs, and their associated (trapezoid) orders 
are precisely those having interval dimension 2 (see Trotter [1992]). 

Langley [1995] and Ma and Spinrad [1994] gave polynomial time algorithms 
for recognizing trapezoid graphs, and Felsner, Miller and Wernisch [1997] have 
given optimal maxclique and maxstable set algorithms for the class. Further 
investigation of the class can be found in Cheah and Corneil [1996]. As we 
will mention below, trapezoid graphs are equivalent to the bounded bitolerance 
graphs. 


Cographs and Factoring Read-Once Functions 


An important subfamily of permutation graphs are the complement reducible 
graphs, or cographs, which were investigated by Corneil, Lerchs and Burlingham 
{1981] and Corneil, Perl and Stewart [1985]. Cographs can be defined recursively 
as follows: (1) a single vertex is a cograph; (2) the disjoint union of cographs is a 
cograph; (3) the complement of a cograph is a cograph. Alternately, they can be 
defined by a restricted type of decomposition, as in our Section 5.2 (page 111) 
where Gr would be either a clique or a stable set. One can recognize whether a 
graph G is a cograph by repeatedly decomposing it in this way, and in linear time 
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obtain a representation called its cotree. The cotree is useful in many algorithms 
for the class. The next theorem gives several characterizations of cographs. 


Theorem 13.7. The following are equivalent for an undirected graph G. 
(i) G is a cograph. 
(ii) G is P4-free. 
(iii) For every subset X of vertices, either the induced subgraph Gy is 
disconnected or its complement Gy is disconnected. 


Recognizing cographs and building the associated cotree has been recently 
used in an application involving multi-level logic synthesis. Golumbic and Mintz 
[1999] presented a factoring algorithm for general Boolean functions which is 
based on graph partitioning, and at the lower levels of the recursion, read-once 
functions are handled in a special manner. Read-once functions are very closely 
related to cographs, as we shall see. 

A Boolean function F is called a read-once function if it has a factored 
form in which each variable appears exactly once. For example, the function 
F, = ag +acp+ace is a read-once function since it can be factored into the 
formula F, = a(g+c(p+e)). The function Fy = ab + ac + bc is not a read-once 
function. Read-once functions have interesting special properties and account 
for a large percentage of functions which arise at the lower level real circuit 
applications. They have also gained recent interest in the field of computational 
learning theory. 

Let F = a; +---+ be given in disjunctive normal form (sum-of-products), 
where each a; is a product term, and let V = {v;,...,v,} be its set of variables. 
We consider the graph ['- = (V,E) of F where u,v; € E whenever vu; and u 
appear together in some product term o,. The function F is called normal if 
every clique of Ir is contained in one of the product terms. Our example F 
above is not normal since ry, is a triangle, but all product terms are of size 
2. The dual F* of F is the function obtained from F by replacing products by 
sums and sums by products. By taking the disjunctive normal form of F* one 
can construct the graph ['r-. The next theorem is due to Gurvich [1991]: 


Theorem 13.8. The following are equivalent: 
(i) F is a read-once function. 
Gi) Tr is P4-free (i.e., a cograph) and F is a normal function. 
(iit) Tp =T pe. 


Golumbic, Mintz and Rotics [2001] present a very fast method for recognizing 
and factoring read-once functions based on algorithms for cograph recognition 
and on checking normality. 
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8. Interval Graphs and Circular-arc Graphs 


AT-Free Graphs 


Three vertices v),02,v3 in a graph G = (V,E) form an asteroidal triple (AT) 
if, for all permutations i,j,k of {1,2,3}, there is a path from vu; to vj which 
avoids using any vertex in the neighborhood N(vu,) = uz U Adj(ug). An easy way 
to verify this for vu, is to delete N(v,) and test whether vu; and v; remain in the 
same connected component of G — N(vu,). It also follows from the definition that 
the three vertices of an asteroidal triple are pairwise nonadjacent. For example, 
the graph in Figure 8.15 (page 196) has 8 asteroidal triples>. 

A graph is called asteroidal triple free or AT-free if it contains no asteroidal 
triple. We saw in Theorem 8.4 (page 174) that interval graphs are characterized 
by being chordal and AT-free. Golumbic, Monma and Trotter [1984] proved the 
following result. 


Theorem 13.9. Every cocomparability graph is an AT-free graph. 


More recently, Corneil, Olariu and Stewart [1997, 1999] have given new 
algorithmic and structural results for AT-free graphs. K6hler [2000] also provides 
efficient recognition algorithms for the class. 


Tolerance Graphs 


Tolerance graphs were introduced by Golumbic and Monma [1982] to 
generalize some of the applications associated with interval graphs. Their 
motivation was the need to solve scheduling problems, more general than what 
we saw in Section 1.3, in which resources such as rooms, vehicles, support 
personnel, etc. may be needed on an exclusive basis, but where a measure of 
flexibility or tolerance would be allowed for sharing or relinquishing the resource 
when total exclusivity prevented a solution. The recent book by Golumbic and 
Trenk [2004] contains a thorough study of tolerance graphs and related topics. 

An undirected graph G = (V,£) is a tolerance graph if there exists a collection 
T = {I}ver of closed intervals on the real line and an assignment of positive 
numbers f = {t,}ucy such that 


weEs{I,ol,| > min{t, ty}. 
Here |/,,| denotes the length of the interval J. The positive number f, is called the 


tolerance of v, and the pair (Z,t) is called an interval tolerance representation 
of G. A tolerance graph is said to be bounded if it has a tolerance representation 


5 In this book, we incorrectly spelled these “astroidal” rather than asteroidal. 
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in which t, < |J,| for all v € V. Tolerance graphs generalize both interval graphs 
and permutation graphs, and in Golumbic and Monma [1982] it was shown that 
every bounded tolerance graph is a cocomparability graph. Golumbic, Monma 
and Trotter [1984] proved that tolerance graphs are perfect and are contained in 
the class of weakly chordal graphs. 

Coloring bounded tolerance graphs in polynomial time is an immediate 
consequence of their being cocomparability graphs. Narasimhan and Manber 
[1992] use this fact (as a subroutine) to find the chromatic number of any 
(unbounded) tolerance graph in polynomial time, but not the coloring itself. 
Golumbic and Siani [2002] give an O(qn + nlogn) algorithm for coloring 
a tolerance graph, given the tolerance representation with q vertices having 
unbounded tolerance (see Golumbic and Trenk [2004]). The complexity of 
recognizing tolerance graphs and bounded tolerance graphs remain open 
questions. 

A variety of “variations on the theme of tolerance” in graphs have been defined 
and studied over the past years. By substituting a different “host” set instead 
of the real line and with a specified type for the subsets of that host instead 
of intervals, we obtain classes such as neighborhood subtree tolerance (NeST) 
graphs, tolerance graphs of paths on a tree or tolerance competition graphs. By 
changing the function min for a different binary function @ (for example, max, 
sum, product, etc.), we obtain a class that will be called -tolerance graphs. 
By replacing the measure of the length of an interval by some other measure 
Ut of the intersection of the two subsets (for example, cardinality in the case 
of discrete sets, or number of branching nodes or maximum degree in the case 
of subtrees of trees), we could obtain yet other variations of tolerance graphs. 
When we restrict the tolerances to be 1 or o0, we obtain the class of interval 
probe graphs. By allowing a separate leftside tolerance and rightside tolerance 
for each interval, various bitolerance graph models can be obtained. For example, 
Langley [1993] showed that the bounded bitolerance graphs are equivalent to the 
class of trapezoid graphs. Directed graph analogues to several of these models 
have also been defined and studied. For further study of tolerance graphs and 
related topics, we refer the reader to Golumbic and Trenk [2004]. 


Circular-Arc Graphs 


In Section 8.6, we presented the early work on circular-arc graphs, the 
intersection graphs of arcs on a circle. The first polynomial time algorithm 
for recognizing circular-arc graphs was given by Tucker [1980] and had 
complexity O(n*). Over the years, more efficient algorithms were designed for 
the recognition problem first by Hsu [1995] in O(me) and Eshen and Spinrad 
[1993] in O(n’), and most recently by McConnell [2001, 2003] in O(n + e) which 
is optimal. The coloring problem for circular-arc graphs was shown to be NP- 
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complete by Garey, Johnson, Miller and Papadimitriou [1980]. The maximum 
stable set and the maximum clique problems are polynomial, see Golumbic and 
Hammer [1988], Hsu and Spinrad [1995], Hsu [1985], Apostolico and Hambrus 
[1987]. 


9. Superperfect Graphs 


Superperfect Noncomparability Graphs 


Progress has been made on the question asked in Section 9.4, ““When does 
superperfect equal comparability?” Gallai [1967] published a complete list of the 
minimal noncomparability graphs, that is, the noncomparability graphs with the 
property that removing any vertex makes the remaining subgraph a comparability 
graph, see also Berge and Chvatal [1984, p. 78]. Using this list, Andreae [1985] 
determined all of the minimal noncomparability graphs which are superperfect. 
One of these is the graph in our Figure 1.18 on p.18 which we incorrectly 
placed in the position of non-superperfect in Figure 9.9 on p. 212. This graph 
is superperfect and a simple proof is also given in Kloks and Bodlander [1992, 
Theorem 3.2]. 

In Corollary 9.8, we saw that for split graphs, G is a comparability graph if 
and only if G is superperfect. This motivated our asking the question of whether 
or not this equivalence holds for triangulated graphs or for cotriangulated graphs. 
Using his forbidden subgraph characterization of superperfect noncomparability 
graphs, Andreae [1985] answered this question with “false” for triangulated 
graphs and “true” for cotriangulated graphs, showing the following. 


Theorem 13.10. 
(i) For cotriangulated graphs, G is a comparability graph if and only if G is 
superperfect. 
(ii) For triangulated graphs, G is a comparability graph if and only if G is 
superperfect and contains no induced subgraph isomorphic to G;, G2 or G3 
of Figure 13.2. 


As Andreae [1985] points out, this list of the minimal superperfect non- 
comparability graphs could also be used to answer our equivalence question 
for other hereditary classes of graphs. In a similar investigation for k-trees, 


Fig.13.2. The minimal triangulated, superperfect noncomparability graphs. 
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Kloks and Bodlander [1992] gave a complete characterization, by means of 
forbidden subgraphs, of the superperfect 2-trees. The graph G, is a superperfect 
2-tree. They also give an algorithm for testing superperfection in k-trees, whose 
complexity is linear for any fixed k, and can produce a complete forbidden 
subgraph characterization of superperfect k-trees. 


10. Threshold Graphs 


The undisputed authority on threshold graphs and related topics is the book 
by Mahadev and Peled [1995]. It is a masterpiece of clarity, and it presents 
a comprehensive coverage of Ferrers digraphs, threshold dimension, measures, 
weights, orders, enumeration, and a variety of generalizations, variations and 
specializations of threshold graphs. Any intention of updating or expanding upon 
Chapter 10 must therefore defer to their book. 

New complexity results on the threshold dimension of a graph deserve 
mentioning. In Section 10.1, we defined the threshold dimension 6(G) of a graph 
G. Threshold graphs are those having threshold dimension at most 1, and they 
can be recognized in linear time. The complexity of determining @(G) is NP- 
complete (page 223), and a stronger result is that determining whether 0(G) < k, 
for any fixed k > 3, is NP-complete (Golumbic [1981], Yannakakis [1982]). So 
the remaining question, open for the next dozen years, was whether recognizing 
threshold dimension 2 could be done in polynomial time. A positive answer to 
this question follows from the next interesting result. 

Two edges of G are said to conflict if their endpoints induce in G one of the 
forbidden subgraphs C4, P4 or 2K> characterizing threshold graphs (see Theorem 
10.7, page 227). The conflict graph G* of G is defined by taking V(G*) = E(G) 
and by joining two vertices of G* by and edge in £(G*) if and only if their 
corresponding edges in G conflict. For example, the conflict graph of a threshold 
graph is a stable set, and the conflict graph of Cy is 2K). We noted in Section 
10.1, that we can take 6(G) to be the minimum number of threshold graphs 
needed to cover the edges of G. Thus, Chvatal and Hammer [1977] observed that 
such an edge covering of G leads to a valid coloring of G*, that is, ¥(G*) < 6(G) 
where each color represents a threshold graph in the edge covering. From this 
inequality, one can see that whenever G has threshold dimension 2, its conflict 
graph G* must be a bipartite graph. The converse of this implication for 6(G) = 2 
was conjectured to hold by Ibaraki and Peled [1981], and it was finally proven 
by Raschle and Simon [1995], which we record as follows. 


Theorem 13.11. A graph G has threshold dimension 2 if and only if its conflict 
graph G* is a bipartite graph. 
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A proof of this theorem can be found in Mahadev and Peled [1995, Section 
8.5]. Since constructing the conflict graph and testing whether it is 2-colorable 
can be done in polynomial time, we immediately obtain the following corollary. 


Theorem 13.12. The problem of determining whether 6(G) < 2 has poly- 
nomial time complexity. 


Threshold Hypergraphs 


In Section 10.4, we presented the definition of threshold hypergraph and gave 
an application in which they might be useful for the allocation of resources. 
Threshold hypergraphs are closely related to the class of threshold Boolean 
functions. We also posed a Research Problem (on page 233) giving three 
properties of r-regular hypergraphs, each being a generalization of threshold 
graphs to hypergraphs. Reiterman, et al. [1985] have shown that these three 
properties are different, and they have given a characterization of the most 
general of them (73) which are known as shift stable r-regular hypergraphs. 
Boros [1991] has generalized this further, giving a characterization of shift stable 
hypergraphs (not necessarily regular ones). 


11. Circle Graphs 


Circle graphs are the intersection graphs of chords of a circle. In Chapter 
11, we called these “not so perfect graphs” rather as a joke, needing an excuse 
to include them in the book even though they are not perfect graphs. Circle 
graphs are an important and natural extension of permutation graphs, and their 
equivalence with overlap graphs raises their status even further. The recognition 
problem for circle graphs, which had been open, was solved independently by 
Bouchet [1987] and Gabor, Supowit, and Hsu [1989] who gave polynomial 
algorithms with complexity of O(n*) and O(n*), respectively. Subsequently, an 
O(n’) method was given by Spinrad [1994]. A further characterization of circle 
graphs appears in Bouchet [1994]. 


12. Chordal Bipartite Graphs 


We defined the class of chordal bipartite graphs in Section 12.4 as those 
bipartite graphs which, for all k > 4, have no induced chordless cycle C;,. Thus, 
a chordal bipartite graph is not necessarily a chordal graph since the 4-cycle C4 
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is chordal bipartite but not chordal®. Recalling the definition of weakly chordal 
graphs (Section 13.4 above), it is a simple exercise to show the following: 


Theorem 13.13. An undirected graph G is chordal bipartite if and only if G 
is bipartite and weakly chordal. 


Chordal bipartite graphs are also related to strongly chordal graphs and to 
totally balanced matrices. A 0/1 matrix is called totally balanced if it does 
not contain as a submatrix the (vertex-edge) incidence matrix of a cycle of 
length > 3. A 0/1 matrix is called I’-free if it does not contain a submatrix of the 
form cae Anstee and Farber [1984], Hoffman, Kolen and Sakarovitch [1985] 
and Lubiw [1987] proved the following: 


Theorem 13.14. A 0/1 matrix is totally balanced if and only if its rows and 
columns can be permuted so that the resulting matrix is T-free. 


Let G = (V,E) be an undirected graph with V = {v;,...,v,}. We define 
the clique-vertex incidence graph of G to be the bipartite graph H(G) with the 
vertices of G on one side and the maximal cliques of G on the other side, such 
that a vertex v of G is adjacent to a clique K of G in H(G) if and only ifv isa 
member of K in G. In Section 8.2 (page 174), studying the characterizations of 
interval graphs, we defined a similar notion, the cligue-vertex incidence matrix 
of G which we denote by M = M(G). 

Finally, we define B(G) = (X,Y,E’) to be the bipartite graph where 
X = {x1,...,%n}, Y = {n,-...yn} and B’ = {xiy; |v; € V} U {xij | vjny € E}. 
The graph B(G) is, in fact, the same as the closed neighborhood-vertex incidence 
graph of G. 

The following theorem is due to Farber [1983]. 


Theorem 13.15. The following conditions are equivalent: 
(i) G is a strongly chordal graph. 
(ii) H(G) is a chordal bipartite graph. 
(iii) M(G) is a totally balanced matrix. 
(iv) B(G) is a chordal bipartite graph. 


We mention another interesting equivalence which follows essentially from our 
proof of Theorem 12.1, and was stated explicitly later in Brandstadt [1991]. 


6 When I introduced the term “chordal bipartite graph” in 1978, my thinking was that the word 
“chordal” in this context should be interpreted as an adjective permitting cycles of the smallest 
possible length (length 3 for graphs in general, or length 4 for bipartite graphs) but requiring 
that any larger cycle must have a chord. Thus, the meaning of “chordal” was context dependent, 
admittedly a somewhat confusing matter. Indeed, this criticism is voiced in Brandstadt, Le and 
Spinrad [1999, page 41]. Clearly, a graph G is both a chordal graph and bipartite if and only if G 
is a forest of trees. 
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Theorem 13.16. An undirected graph G is a chordal graph if and only if B(G) 
is a perfect elimination bipartite graph. 


Our Corollary 12.11 (page 263) related chordal bipartite graphs to perfect 
elimination bipartite graphs by adding the hereditary property to the latter. We 
now present two additional characterizations of chordal bipartite graphs. 

Let H = (X, Y,£) be a bipartite graph, and let o = [e;,..., @,] be an ordering 
of the edges. Define H; = (X, Y,E;) where E; = {e;,...,@m}, that is, H; is the 
graph obtained by erasing the edges e),...,¢;-1, but not their endpoints. We call 
0 a perfect “edge-without-vertex” erasing ordering if e; is bisimplicial in Hj. 

Denote by Splity(#) the split graph obtained by completing Y into a clique. 

In the following theorem, the equivalence (1) <=> (ii) is due to Dalhaus [1991], 
and several researchers, according to Brandstadt, Le and Spinrad [1999], have 
observed (1) <=> (iil). 


Theorem 13.17. The following conditions are equivalent for a bipartite graph 
: 
(i) A is a chordal bipartite graph. 
(ii) Splity(#) is a strongly chordal graph. 
(iii) H has an edge-without-vertex erasing order. 


Further results on chordal bipartite graphs, relating them to vertex orderings, 
totally balanced matrices, matrices having a I-free ordering, and other classes, 
can be found throughout Brandstadt, Le and Spinrad [1999]. Minimum triangu- 
lations of chordal bipartite graphs are studied in Kloks [1994]. 


A Final Note on Terminology 


Samuel Eilenberg, one of the leading mathematicians of the twentieth 
century, and my doctoral thesis advisor, objected strenuously against the use 
of mathematical terms such as “partial function”. In his view, an adjective 
modifying a noun should specialize the mathematical concept represented by 
the noun and not generalize it. Since a partial function is not a function at all, 
but rather a mapping which is defined on only part of its domain, 1.e., a partially 
defined function, he regarded such terms as an imprecise abuse of language. 
For him, semigroups were always monoids (with identity), and he would have 
disliked weakly chordal graphs. 

Thus, quite correctly, a subset is a set, a recursive function is a function, an 
alligator purse is a purse, and a strongly chordal graph is a chordal graph, which 
in turn is a graph. The “‘is-a” hierarchy is a partial order (whoops!) is a partially 
ordered set (whoops again!) is simply an order. 

The terminology we used in this book, and subsequently, has tried to follow 
this principle. For example, we prefer to use the terms interval tolerance graphs 
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and neighborhood subtree tolerance graphs when referring to these classes, but 
never tolerance interval graphs since the concept of an interval graph is so firmly 
established in the literature. Similarly, we insist on using the term interval probe 
graphs, The use of chordal bipartite graph is consistent with this approach, but 
has caused confusion. It is never possible to get it right every time, but we hope 
that there will be enough tolerance on both sides of the interval to keep the 
conflict graph very sparse. 
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Fig.13.3. A complete hierarchy of classes of perfect graphs ordered by inclusion. Reprinted from 
Golumbic and Trenk [2004]. 
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